如何将字符串拆分为包含前一个最后一个字符的两个字符的字符串数组



我有这个词,我想在每次拆分迭代中取最后一个前一个字符,将它拆分成数组。

string word = "HelloWorld!";
string[] mystringarray = word.Select(x => new string(x, 2)).ToArray();
Console.WriteLine(mystringarray);

输出结果:

[HH,ee,ll,oo,WW,oo,rr,ll,dd,!!]

预期结果:

[He,el,ll,lo,ow,wo,or,rl,ld]

我怎样才能做到这一点?

如果您想要LINQ解决方案,可以使用Zip:

string[] mystringarray = word
.Zip(word.Skip(1), (a, b) => $"{a}{b}")
.ToArray();

这将使用Skip作为偏移量,将word中的每个字符与其自身压缩,并且仍然具有与显式循环一样的O(n)复杂性。

string word = "HelloWorld!";
List<string> mystringarray = new();
for (int i = 1; i < word.Length; i++)
{
mystringarray.Add(word.Substring(i-1, 2));
}

mystringarray:的内容

List<string>(10) { "He", "el", "ll", "lo", "oW", "Wo", "or", "rl", "ld", "d!" }

记下感叹号,我不确定你是否想把它包括在内。

我认为下面的代码实现了您想要的输出。其算法为:

(0, 1),
(1, 2),
(2, 3),
......

string[] mystringarray = word.
Select((x,i) => 
i == 0 || i + 1 == word.Length ? x.ToString() : x + word.Substring(i,1))
.ToArray();

或使用Enumerable.Range

string[] mystringarray2 = Enumerable.Range(0, word.Length).
Select(i => i == 0 || i + 1 == word.Length ? word[i].ToString() : word[i] + word.Substring(i,1))
.ToArray();

最新更新