我正在尝试按其值排序C#Dictionary<int, int>
而不使用LINQ的OrderBy
,因为iPhone不支持它。
我似乎无法弄清楚,所以非常感谢你的帮助!
答案 0 :(得分:3)
有很多可行的方法可以做到这一点。以下所有假设myDictionary
是要排序的原始字典。
var myList = myDictionary.ToList();
myList.Sort((a, b) => a.Value.CompareTo(b.Value));
var myArray = myDictionary.ToArray();
Array.Sort(myArray, (a, b) => a.Value.CompareTo(b.Value));
只有当您知道每个值只出现一次时,此解决方案才适用。
var mySortedDict = new SortedDictionary<int, int>();
foreach (var kvp in myDictionary)
mySortedDict[kvp.Value] = kvp.Key;
此解决方案仅在值可以多次出现时才适用。
var mySortedDict = new SortedDictionary<int, List<int>>();
foreach (var kvp in myDictionary)
{
if (!mySortedDict.ContainsKey(kvp.Value))
mySortedDict[kvp.Value] = new List<int>();
mySortedDict[kvp.Value].Add(kvp.Key);
}
答案 1 :(得分:0)
我们可以生成List
KeyValuePair
,然后使用Sort
对其进行排序,
Dictionary<int, int> myList = new Dictionary<int, int>();
List<KeyValuePair<int, int>> mySortedList = myList.ToList();
mySortedList.Sort(( firstValue, nextValue) =>
{
return firstValue.Value.CompareTo(nextValue.Value);
}
);
Dictionary<int, int> mySortedDict = mySortedList.ToDictionary(keyItem => keyItem.Key, keyItem => keyItem.Value);
我认为iPhone上将支持Sort