如标题:
对于随机生成的字符串,本文中将其存取在定义的一个全局数组中,然后每次随机生成的数与已存入数组中的字符串进行比较,若是一致,则放弃新生成的字符串,返回重新再生成,否则将字符串存入数组,并返回值。
while(1)其中1代表一个常量表达式,它永远不会等于0。循环会一直执行下去。除非你设置break等类似的跳出循环语句循环才会中止。
以下算法,定义了一个flag,若是flag不为ture,则无法退出while循坏,重新执行随机生成字符串的算法以及判断是否重复的算法。
Math.floor():返回小于等于x的最大整数
主要代码如下:
function randomCoding(n)
{
var str = '2345679abcdefghijkmnpqrstuvwxyzACDEFGHJKLMNPQRSTUVWXYZ'; //数组规定随机生成字符串的取值
var a = str.length-1;
var b = str.length;
while(1){
var result = ''; //每次都清空
for (var i = n; i > 0; --i) {
var index = Math.floor(Math.random() * b);
if(index == b){
//index -= 1;
index = Math.floor(Math.random() * a); //越界处理,再进行一轮随机生成,取值为0到长度-1
}
result+=str[index];
}
var flag =true;
for(var i=0;i<globalInfos.arr.length;i++){
if(globalInfos.arr[i]==result){ //逐一与全局数组进行比较
flag= false;
break;
}
}
if(flag){
break;
}
}
globalInfos.arr.push(result); //存入数组
return result;
}