zoukankan      html  css  js  c++  java
  • 算法基础系列之二:随机数及重复字符统计

    //程序一定有些不好、不对的地方,还请大大们一定告诉我

    //1.如何按随机顺序输出11010个数,这是我一次面试时人家问的?

    static void Main(string[] args)

    {

        int[] intArray = new int[10];

        for (int i = 0; i < 10; i++)

        {

            intArray[i] = i + 1;

        }

     

        Random r = new Random();

        for (int i = 9; i >= 0; i--)

        {

            int index = r.Next(i+1);

            Console.WriteLine(intArray[index].ToString());

            if (index != i)

            {

                intArray[index] = intArray[i];

            }

        }

     }

     

     

    //2.统计字符串中重复次数最多的字符

    //方法一:

    static void CountRepeat(string s)

    {

        List<char> list = new List<char>();

        list.AddRange(s.ToCharArray());

        list.Sort();

     

        char c = list[0];

        int temp = 1;

        char maxChar = ' ';

        int maxCount = 0;

     

        for (int i = 1; i < list.Count; i++)

        {

            if (list[i] == c)

            {

                temp++;

            }

     

            if (list[i] != c || i == list.Count - 1)

            {

                if (temp > maxCount)

                {

                    maxCount = temp;

                    maxChar = c;

                }

                temp = 1;

            }

            c = list[i];

        }

        Console.WriteLine(maxChar.ToString() + "  " + maxCount.ToString());

     

    }

     

    //方法二:

    static void CountRepeat(string s)

    {

        Dictionary<char, int> dict = new Dictionary<char, int>();

        char maxChar = Char.MinValue;

        int maxCount = 0;

     

        foreach (char c in s)

        {

            if (dict.ContainsKey(c))

            {

                dict[c]++;

            }

            else

            {

                dict.Add(c, 1);

            }

        }

        foreach (KeyValuePair<char, int> kvp in dict)

        {

            if (kvp.Value > maxCount)

            {

                maxCount = kvp.Value;

                maxChar = kvp.Key;

            }

        }

        Console.WriteLine(maxChar.ToString() + "  " + maxCount.ToString());

    }

  • 相关阅读:
    javascript笔记:深入理解javascript的function
    java笔记:SpringSecurity应用(二)
    javascript笔记:临摹jQuery(二)
    javascript笔记:临摹jQuery(一)
    java笔记:SpringSecurity应用(一)
    javascript笔记:javascript的前世,至于今生嘛地球人都知道了哈
    使用AJAX和J2EE创建功能强大的瘦客户端
    阻止事件冒泡
    Pro JavaScript Techniques第一章: 现代javscript编程
    JS数组方法汇总 array数组元素的添加和删除
  • 原文地址:https://www.cnblogs.com/morvenhuang/p/499417.html
Copyright © 2011-2022 走看看