zoukankan      html  css  js  c++  java
  • 通过LinQ查询字符出现次数

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

    我的实现方法是将所有题目选中的选项拼接为一个字符串,如: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();
  • 相关阅读:
    R语言入门视频笔记--2--一些简单的命令
    Java 虚拟机内存优化
    Apollo 配置中心
    Apollo本地缓存文件
    SpringBoot 远程调试
    SpringCloud微服务架构下 部署在ECS上 403
    Nginx 常用命令
    阿里云数据库Redis版 ERR invalid password
    Apollo配置中心搭建
    Gateway 访问超时 返回504
  • 原文地址:https://www.cnblogs.com/songhaipeng/p/3430644.html
Copyright © 2011-2022 走看看