在一個項目中使用到一個問卷調查,在用戶完成之后,需要統計所有題目中哪一個選項被選中次數最多。
我的實現方法是將所有題目選中的選項拼接為一個字符串,如:ABCADAA
在分析被選中次數的時候最初是將字符串變為字符數組,然后進行遍歷統計,代碼如下:
public static int GetMaxDiaplayChar(string str, out string val)
{
int times = 0;
val = "";
char max = str[0];
Dictionary<char, int> counter = new Dictionary<char, int>();
foreach (char c in str)
{
if (!char.IsLetter(c)) continue;
if (counter.ContainsKey(c)) counter[c]++;
else counter.Add(c, 1);
if (counter[max] < counter[c]) max = c;
}
times = counter[max];
val = max.ToString();
return times;
}
這樣進行統計效率一般,且感覺有些太復雜了,于是在后期使用LinQ來進行改進,實現方法如下:
string content = "ABCADAA";
var ch = content.ToCharArray();
var query = ch.GroupBy(s => s).OrderByDescending(s => s.Count()).ToList();
for (int ri = 0; ri < query.Count(); ri++)
{
MessageBox.Show(query[ri].Key + " = " + query[ri].Count());
}
這樣就可以比較簡單的統計具體出現次數,如果需要對出現最少或者最多的字符進行統計,只需要對OrderBy和ToList進行修改就可以,比較靈活。
var queryMax = ch.GroupBy(s => s).OrderByDescending(s => s.Count()).SingleOrDefault();
var queryMin = ch.GroupBy(s => s).OrderBy(s => s.Count()).SingleOrDefault();