第一个 GUID字符串:
A-B-C-D
第二个 GUID字符串:
W-X-Y-Z
第三个必需的可逆字符串:
A -W- B -X- C -Y- D -Z
加入第 1 和第 2 以获得第 3 的最佳方法是 什么,然后将其分开以获得两者?
Join-Split、Aggregate、Zip 还是其他?
编辑 I:
如果每个 GUID 都被假定为Enumerable<String>
{ A,B,C,D } ,也许 LINQ ?
最好的方法?我不确定。但我发现这是一种简单的方法。
string g1 = "A-B-C-D";
string g2 = "W-X-Y-Z";
var result = String.Join("-",g1.Split('-').Zip(g2.Split('-'), (a,b) => a+"-"+b));
编辑
并回来
int i=0;
var gs = result.Split('-').GroupBy(_ => i++ % 2).Select(g => String.Join("-",g))
.ToList();
string str1 = "A-B-C-D";
string str2 = "W-X-Y-Z";
合并:
string merged = string.Join("-",
str1.Split('-').Zip(str2.Split('-'), (a, b) => a + "-" + b).ToArray());
结果:
A-W-B-X-C-Y-D-Z
分开:
ILookup<int, string> split = merged.Split('-')
.Select((a, i) => new { i = i, val = a })
.ToLookup(x => x.i % 2, x => x.val);
string split1 = string.Join("-", split[0].ToArray());
string split2 = string.Join("-", split[1].ToArray());
结果:
A-B-C-D
W-X-Y-Z
我不知道“什么是最好的方法”,但你可以用一个简单的“for”循环来做到这一点:
string a = "ABCD";
string b = "WXYZ";
string c = string.Empty;
if(a.Lenght == b.Lenght)//Check lenght
{
for(int i = 0; i < a.Lenght; i++)
{
c += a[i] + "-" + b[i];
if(i != a.Lenght)//If it isn't last character
{
c += "-";//Add a "-" end of "c"
}
}
}
如果语法不是 100%,请原谅我,C# 不是我的第一语言,但我会将每个 GUID 拆分为一个列表。然后是一个简单的循环。
List<string> lstGuid1 = new List<string>;
List<string> lstGuid2 = new List<string>;
lstGuid1.AddRange(guid1.ToString().Split("-"));
lstGuid2.AddRange(guid2.ToString().Split("-"));
string guid3 = null;
if(lstGuid1.Length == lstGuid2.Length)
{
for(int i = 0; i < lstGuid1.Length; i++)
{
guid3 += lstGuid1[i] + "-" + lstGuid2[i] + "-";
}
guid3 = guid3.Substring(0, guid3.Length - 1);
}