C#按字母顺序和长度对数组字符串进行排序

本文关键字:数组 字符串 排序 顺序 | 更新日期: 2023-09-27 17:51:16

我正在尝试对StringArrayList进行排序。

给定:

{A,C,AA,B,CC,BB}

Arraylist.Sort给出:

{A,AA,B,BB,C,CC}

我需要的是:

{A,B,C,AA,BB,CC}

C#按字母顺序和长度对数组字符串进行排序

ArrayList list = new ArrayList {"A","C","AA","B","CC","BB"};
var sorted = list.Cast<string>()
                 .OrderBy(str => str.Length)
                 .ThenBy(str => str);
//LinqPad specific print call
sorted.Dump();

打印:

A 
B 
C 
AA 
BB 
CC 

使用Linq这样做更容易:

string [] list = { "A","C","AA","B","CC","BB"};
var sorted = list.OrderBy(x=>x.Length).ThenBy(x=>x);

请注意,OrderBy方法返回一个新列表。如果你想修改原件,那么你需要重新分配:

list = list.OrderBy(x=>x.Length).ThenBy(x=>x).ToArray();

这是一种老派,但我去了IComparer接口。

public class SortAlphabetLength : System.Collections.IComparer
{
    public int Compare(Object x, Object y)
    {
        if (x.ToString().Length == y.ToString().Length)
            return string.Compare(x.ToString(), y.ToString());
        else if (x.ToString().Length > y.ToString().Length)
            return 1;
        else
            return -1;
    }
}

然后测试它。

class Program
{
    static void Main(string[] args)
    {
        ArrayList values = new ArrayList()
        {
            "A","AA","B","BB","C","CC"
        };
        SortAlphabetLength alphaLen = new SortAlphabetLength();
        values.Sort(alphaLen);
        foreach (string itm in values)
            Console.WriteLine(itm);
    }
}

输出:

A
B
C
AA
BB
CC

我建议使用ToArray()方法(或仅使用ArrayList的List<string> instad(来利用OrderByThenBy函数。它看起来像这样:

list = list.OrderBy(/*Order it by length*/).ThenBy(/*Order alphabetically*/);

您可以创建一个IComparable类,接受两个String并按如下方式对它们进行排序:

if (a.Length == b.Length)
    return String.Compare(a, b);
return a.Length.CompareTo(b.Length);

您可能还需要处理null案例。