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下才有的,能充分体现微软对语言改进行的开发效率性
诚然,这样了也使程序员们更傻瓜式的编程!