通过LinQ查询字符出现次数的实例方法
通过LinQ查询字符出现次数的实例方法
发布时间:2016-12-28 来源:查字典编辑
摘要:在一个项目中使用到一个问卷调查,在用户完成之后,需要统计所有题目中哪一个选项被选中次数最多。我的实现方法是将所有题目选中的选项拼接为一个字符...

在一个项目中使用到一个问卷调查,在用户完成之后,需要统计所有题目中哪一个选项被选中次数最多。

我的实现方法是将所有题目选中的选项拼接为一个字符串,如: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();

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新C#教程学习
热门C#教程学习
编程开发子分类