目前,我正在尝试实现一个代码来生成频繁的序列。在这样做时,我需要获得一个就地排列的字符串列表,如下所示:
List<List<string>> myList = new List<List<string>>();
List<string> input1 = new List<string>() {"a", "b", "d"};
List<string> input2 = new List<string>() {"a", "b", "c"};
myList.Add(input1);
myList.Add(input2);
我需要的输出是:
myList = {{"a","b","c"},{"a","b","d"}};
我尝试使用myList.Sort()
,但它提出了System.InvalidOperationException
。
我对LINQ不是那么好,所以我没有使用任何类似的东西。
答案 0 :(得分:2)
怎么样:
myList = myList.OrderBy(s => string.Join(string.Empty, s)).ToList();
诀窍是根据子列表的每个元素的串联所做的字符串进行排序。
答案 1 :(得分:1)
如果您想使用Sort()
解决,可以使用此方法
myList.Sort((x, y) => x.Zip(y,(l1,l2) => string.Compare(l1,l2)).FirstOrDefault(c => c != 0));
否则我会将所有项目合并为一个string
并进行比较。
效率较低,因为必须首先创建字符串对象。
myList = myList.OrderBy(string.Concat).ToList();
答案 2 :(得分:0)
您可以尝试以下代码:
List<string> input1 = new List<string>() { "a", "b", "d" };
List<string> input2 = new List<string>() { "a", "b", "c" };
//Instead of adding input as List<string>, add it as string
string delimiter = ",";
var input1Str = input1.Aggregate((i, j) => i + delimiter + j);
var input2Str = input2.Aggregate((i, j) => i + delimiter + j);
var myListStr = new List<string>();
myListStr.Add(input1Str);
myListStr.Add(input2Str);
myListStr.Sort();
//Now you can convert it into List<List<string>>
List<List<string>> myList = myListStr.Select(x => x.Split(',').ToList()).ToList();
答案 3 :(得分:0)
您也可以使用
myList = myList.OrderBy(arr => arr[0])
.ThenBy(arr => arr[1])
.ThenBy(arr => arr[2])
.ToList();