background image

经典的解答思路为:取出字符串的第一个字符(首字母),利用的字符串的 replace 方
法将符合正则表达式(第一个字符)替代为空,此字母出现的次数为原始的字符串长度
减去替代后的字符串长度。循环迭代找出长度最长的字母。

<script type="text/javascript">
var str ="adadfdfseffserfefsefseeffffftsdg"; //命名一个变量放置给出的字符串
var maxLength = 0; //命名一个变量放置字母出现的最高次数并初始化为 0
var result = ''; //命名一个变量放置结果输入

while( str != '' ){ //循环迭代开始,并判断字符串是否为空
   oldStr = str; //将原始的字符串变量赋值给新变量
   getStr = str.substr(0,1); //用字符串的 substr 的方法得到第一个字符(首字母)
   eval("str = str.replace(/"+getStr+"/g,'')"); //详细如补充

   if( oldStr.length-str.length > maxLength ) { //判断原始的字符串的长度减去替代
后字符串长度是否大于之前出现的最大的字符串长度
maxLength = oldStr.length-str.length; //两字符串长度相减得到最大的字符串长度
result = getStr + "=" + maxLength //返回最大的字符串结果(字母、出现次数)
}
}
alert(result) //弹出结果
</script>

 

Q:一个长度为 10000 的字符串,通过随机从 a-z 中抽取 10000 个字符组成.请用 c#语
言编写主要程序来实现。

public partial class random : System.Web.UI.Page

{

    protected void Page_Load(object sender, EventArgs e)

    {  //调用--------------- 

        string str = GenerateRandom(10000);

        Response.Write(str);

    }