CSDN上一篇帖子:用最少的代码从一个字符串中找到出现频率最高的字符

CSDN上一篇帖子:
用最少的代码从一个字符串中找到出现频率最高的字符

一/自己用HashTable(或SortedList)写了下遍历的代码:

 

 using System.Collections;

string bb = "adfjdkdkksksks233cdk"; 
Hashtable ht = new Hashtable();
int nCount;
for (int i = 0; i < bb.Length; i++)         //遍历字符串
{
    nCount = 0;
    if (ht.Contains(bb[i]))                //Hashtable是否包含该Key,如果包含则进入下一个循环
        continue;
    for (int j = 0; j < bb.Length; j++)   
    {
        if (bb[i] == bb[j])
        {
            nCount++;                     //对比统计
        }
    }

    if(!ht.Contains(bb[i]))
        ht.Add(bb[i], nCount);            //往Hashtable添加对应Key和Value
}

//循环输出各字符出现次数
foreach (DictionaryEntry objDE in ht)
{
   Response.Write("Key:" +objDE.Key.ToString()+"\tvalue值:"+objDE.Value.ToString()+"<br>");
}

 

 

二/在CSDN上用linq实现,其中用linq(lambda表达式)实现代码如下:
string str="fffffsfdfdfdfssssssssssssffffffffffffffggggggggg";
char c = str.ToCharArray().GroupBy(ch => ch).OrderBy( g => -g.Count() ).First().Key;

这过这种表达式只有.net framework3.5下才有的,能充分体现微软对语言改进行的开发效率性
诚然,这样了也使程序员们更傻瓜式的编程!

你可能感兴趣的:(csdn)