通过LinQ查询字符出现次数的实例方法
2023-06-13 09:15:12 时间
在一个项目中使用到一个问卷调查,在用户完成之后,需要统计所有题目中哪一个选项被选中次数最多。
我的实现方法是将所有题目选中的选项拼接为一个字符串,如:ABCADAA
在分析被选中次数的时候最初是将字符串变为字符数组,然后进行遍历统计,代码如下:
publicstaticintGetMaxDiaplayChar(stringstr,outstringval)
{
inttimes=0;
val="";
charmax=str[0];
Dictionary<char,int>counter=newDictionary<char,int>();
foreach(charcinstr)
{
if(!char.IsLetter(c))continue;
if(counter.ContainsKey(c))counter[c]++;
elsecounter.Add(c,1);
if(counter[max]<counter[c])max=c;
}
times=counter[max];
val=max.ToString();
returntimes;
}
这样进行统计效率一般,且感觉有些太复杂了,于是在后期使用LinQ来进行改进,实现方法如下:
stringcontent="ABCADAA";
varch=content.ToCharArray();
varquery=ch.GroupBy(s=>s).OrderByDescending(s=>s.Count()).ToList();
for(intri=0;ri<query.Count();ri++)
{
MessageBox.Show(query[ri].Key+"="+query[ri].Count());
}
这样就可以比较简单的统计具体出现次数,如果需要对出现最少或者最多的字符进行统计,只需要对OrderBy和ToList进行修改就可以,比较灵活。
varqueryMax=ch.GroupBy(s=>s).OrderByDescending(s=>s.Count()).SingleOrDefault();
varqueryMin=ch.GroupBy(s=>s).OrderBy(s=>s.Count()).SingleOrDefault();