按字典顺序排序的字符串列表列表

时间:2017-04-25 09:58:14

标签: c# list sorting

目前,我正在尝试实现一个代码来生成频繁的序列。在这样做时,我需要获得一个就地排列的字符串列表,如下所示:

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不是那么好,所以我没有使用任何类似的东西。

4 个答案:

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

示例:https://dotnetfiddle.net/1VmohI

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