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

How can I split string into array of string that take two characters with including the previous last character?

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

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]

我怎样才能做到这一点?

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!" }

注意感叹号,我不确定您是否想要包含它。

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

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

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

我认为下面的代码实现了你想要的输出。 它的算法是:

(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();