如何在字典中统一两个数组?
如果你有两个数组string[] a
和int[] b
怎样才能最有效地获得Dictionary
并且代码最少? 假设它们包含相同数量的元素。
例如,这是最好的方法吗?
Dictionary vals = new Dictionary(); for(int i = 0; i < size; i++) { vals.Add(a[i],b[i]); }
如果您的目标是匹配序列中的位置,则可以使用Enumerable.Zip
。
int[] myInts = { 1, 2 }; string[] myStrings = { "foo", "bar"}; var dictionary = myStrings.Zip(myInts, (s, i) => new { s, i }) .ToDictionary(item => item.s, item => item.i);
因为你正在使用数组,所以写“longhand”并不是那么久。 但是,您希望事先validation数组的长度是否相等。
var dictionary = new Dictionary(); for (int index = 0; index < myInts.Length; index++) { dictionary.Add(myStrings[index], myInts[index]); }
通常,Linq可以产生更具表现力,更易于理解的代码。 在这种情况下,可以说相反的是正确的。
如果这是.Net 4,那么您可以执行以下操作:
var result = a.Zip(b, (first, second) => new {first, second}) .ToDictionary(val => val.first, val => val.second);
没有Zip,你也可以这样做:
var result = Enumerable.Range(0, a.Length).ToDictionary(i => a[i], i => b[i]);
使用ToDictionary:
int idx = 0; var dict = b.ToDictionary(d => a[idx++]);
var result = a.ToDictionary(x => x, x => b[a.IndexOf(x)]);