统一C#和数组排序
所以我知道如何在PHP中排序数组,并保持键,但我有一些麻烦统一。统一C#和数组排序
可以说我有一个数组 itemcost = new int [10];
itemcost[1] = 100;
itemcost[2] = 300;
itemcost[3] = 900;
itemcost[4] = 300;
itemcost[5] = 100;
itemcost[6] = 300;
什么是排序最好的办法降使成本最高的往上顶,但保持数组键,所以我可以得到相应的def ATT值?
在此先感谢。
var result = Enumerable.Range(0, itemcost.Length)
.OrderByDescending(index => itemcost[index])
.ToList();
result.ForEach(index => Console.WriteLine(index + " : " + itemcost[index]));
将返回按顺序排序的物料成本索引列表。
参见here
排序泛型列表或类/结构的阵列基于类属性或元素属性
创建一个类来保存成本及其索引然后进行排序的数组或列表这个类
你可以添加事件闪避,ATT,成本,每个项目名称属性类
我这里是
public class CostData
{
public int Cost;
public int ID;
public CostData(int CostAmount, int CostID)
{
Cost = CostAmount;
ID = CostID;
}
}
private void button1_Click(object sender, EventArgs e)
{
List<CostData> itemcost = new List<CostData> {
new CostData(100, 1),
new CostData(300, 2),
new CostData(900, 3),
new CostData(300, 4),
new CostData(100, 5),
new CostData(300, 6)
};
List<CostData> SortedList = itemcost.OrderByDescending((CostData i) => i.Cost).ToList();
Console.WriteLine(SortedList[0].Cost.ToString() + " on index " + SortedList[0].ID.ToString());
// you can do same with Arrray
CostData[] itemcost2 = new CostData[] {
new CostData(100, 1),
new CostData(300, 2),
new CostData(900, 3),
new CostData(300, 4),
new CostData(100, 5),
new CostData(300, 6)
};
CostData[] SortedList2 = itemcost2.OrderByDescending((CostData i) => i.Cost).ToArray();
Console.WriteLine(SortedList2[0].Cost.ToString() + " on index " + SortedList2[0].ID.ToString());
}
他需要保持数组的索引。 –
好的修改我的答案 –
有Array.Sort(Array keys, Array items):
在keysArray每个键在itemsArray相应的项目。在排序过程中重新定位某个键时,itemsArray中的相应项目也会重新定位。因此,itemsArray根据keysArray中相应键的排列进行排序。
int[] indices = new int[itemcost.Length];
for (int i = 0; i < itemcost.Length; i++)
{
indices[i] = i;
}
Array.Sort(itemcost, indices);
不要使用单独的值的阵列,使用的是包含用于所有相关的值属性的类的阵列(或列表)。 – CodeCaster
当然,这将是理想的,但问题是,虽然这很容易让我在PHP中做,在C#这是很难做! – Adam
说我有每个项目def,att,cost,name属性什么是最好的存储方式,通过att(降序)排序然后得到列表中的第二项? – Adam