我有一个数组:
int[] months = new int[4] {1, 4, 7, 10};
我希望能够按照给定值对数组进行排序,并使其余部分按原始顺序排序。
假设我想按值为
7
的方式开始对数组进行排序。那么排序后的数组将按以下顺序排列:7, 10, 1, 4
如果以值4
开始,排序后的数组将是以下顺序:4, 7, 10, 1
如何:
var orderedMonths = months.Where(x => x >= 7)
.OrderBy(x => x)
.Concat(months.Where(x => x < 7));
var orderedMonths = months.OrderBy(x => x < 7) // false comes before true
.ThenBy(x => x);
另一方面,如果您想按照出现顺序对两个片段进行排序,我会这样做:
var orderedMonths = months.GroupBy(x => x < 7)
.OrderBy(group => group)
.SelectMany(x => x);
(或者)
var orderedMonths = months.Where(x => x >= 7)
.Concat(months.Where(x => x < 7));
假设这是您已排序的整数数组,您可以
int[] months = new int[4] { 1, 4, 7, 10 };
int value = 10;
int[] chk1 = new int[4];
chk1 = months.SkipWhile(a => a != value).
Concat(months.TakeWhile(a => a != value)).ToArray();
这应该可以让您得到所需的顺序
你能使用列表吗?
int NumberToBeFound = 7;
int IndexOfNumber = -1;
for(int i=0;i<months.count;i++){
if(months[i] == NumberToBeFound){
IndexOfNumber = i;
break;
}
}
List<int> Sorted = new List<int>();
for(int i = IndexOfNumber; i < months.count;i++){
Sorted.Add(months[i]);
}
for(int i = 0; i < IndexOfNumber; i++){
Sorted.Add(months[i]);
}
months = Sorted.ToArray();
int[]
是IEnumerable<int>
。编译器将使用Enumerable
类中的IEnumerable<T>
上的 LINQ to Objects 扩展方法。 - Ani