C#按字母顺序和长度对数组字符串进行排序
本文关键字:数组 字符串 排序 顺序 | 更新日期: 2023-09-27 17:51:16
我正在尝试对String
的ArrayList
进行排序。
给定:
{A,C,AA,B,CC,BB}
Arraylist.Sort
给出:
{A,AA,B,BB,C,CC}
我需要的是:
{A,B,C,AA,BB,CC}
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(来利用OrderBy
和ThenBy
函数。它看起来像这样:
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
案例。