我有以下字典:
Dictionary<int, int> myDict = new Dictionary<int, int>();
myDict.Add(0, 6);
myDict.Add(1, 10);
myDict.Add(2, 6);
myDict.Add(3, 14);
myDict.Add(4, 10);
myDict.Add(5, 10);
我已经知道如何获取所有重复值:
var duplicatedValues = myDict.GroupBy(x => x.Value).Where(x => x.Count() > 1);
但我想要的是以下内容:包含重复值的所有键的列表,但不包括最后一个重复值。所以在我上面的列表中,重复值是 10 和 6,我想要的是以下键的列表:0、1、4(不包括 2 和 5)。
做这个的最好方式是什么?
任何帮助,将不胜感激。提前致谢。
编辑:我确实设法通过修改我在互联网上找到的东西来使用这段代码来做到这一点,但老实说,我发现先从键创建一个字符串然后再返回整数有点愚蠢。我对 Aggregate-command 有点陌生,因此欢迎任何有关如何修改以下代码的帮助:
var lookup = allIDs.ToLookup(x => x.Value, x => x.Key).Where(x => x.Count() > 1);
foreach (var item in lookup) {
var keys = item.Aggregate("", (s, v) => s + "," + v);
string[] split = keys.Split(',');
for (int i = 0; i < split.Length - 1; i++) {
if (!split[i].Equals("")) {
Console.WriteLine("removing card nr: " + split[i]);
CurrentField.removeCardFromField(Convert.ToInt32(split[i]));
}
}
}