for循环小练习

1.求1 x 2 x 3 x 4 x ... x 19 x 20的结果
定义一个变量保存

 var sum=1;
 for(var i =1;i<=20;i++){
    sum=sum*i;
}

2..随机产生20个10~50的正整数存放到数组中,并求数组中的最大值,最小值,平均值及各个元素之和

var arr = [];
var max =0;
var min =50;//因为数组最大就是50所以min最大不能超过50
var sum =0;
for(var i=0;i<20;i++){
    arr[i] = parseInt(Math.random()*40+10);
    sum=sum+arr[i];

    if(max<arr[i]){
        max=arr[i];//如果循环过程中,arr[i]始终是大于定义的最大值的话,arr[i]就是最大值
    }
    if(min>arr[i]){
        min=arr[i];//同理
    }

}
console.log(max);
console.log(min);
console.log(sum);
console.log(sum/20)

3.生成10个0-50之间的随机数,求第二大的值

//法1
var arr=[];
var max =0;//定义一个变量保存最大的值
var max2 =0;//定义变量保存第二大的值
for(var  i=0;i<10;i++){
    arr[i]=parseInt(Math.random()*40+10);
    if(arr[i]>max2){//如果arr中的数比第二大的数大
        max2=arr[i];//找出第二大值
    }
    if(max2>max){
        var temp =max2;//定义一个变量保存第二大值
        max2 = max;//max2就是最大值把第二大值跟最大值交换
        max = temp;
    }
}
console.log(max);
console.log(sec)
console.log(arr);


// 法2
var arr=[];
var maxIndex =0;
var sec =0;
for(var  i=0;i<10;i++){
    arr[i]=parseInt(Math.random()*40+10);
    if(arr[i]>arr[maxIndex]){
        maxIndex=i;
    }
}
for(var i=0;i<10;i++){
    if(i != maxIndex){
        if(arr[i]>sec){
            sec=arr[i];
        }
    }
}
console.log(arr[maxIndex]);
console.log(sec);
console.log(arr);

4.求所有三位数的各个位上的数值之和出现的次数。

如 345 和值 3+4+5 = 12。 最小和值是1(100的和值),最大和值是27(999的和值)。统计和值1-27各出现了多少次

 var arr=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]
    for(var i=100;i<=999;i++){
    var g = parseInt(i%100%10/1);
    var s =parseInt(i%100/10);
    var b =parseInt(i/100);
    var a =g+s+b;
    arr[a]++;
 }

  var arr=[];
  for(var i=0;i<27;i++){
    arr[i]=0;
  }
  for(var i=100;i<1000;i++){
     var g = parseInt(i%100%10/1);
     var s =parseInt(i%100/10);
     var b =parseInt(i/100);
     var sum=g+s+b;
     arr[sum-1]++;
  }
  for(var i=0;i<27;i++){
    console.log("和值"+(i+1)+"出现次数:"+arr[i]);
}

5.随机十万个100 - 500之间的数。求每个数出现的次数

  var arr =[]; // 用一个容器保存所有数出现的次数
  var countArr = [];// 因为共有400个,所以创建数组,并且让数组的所有值初始都等于0
  for(var i =0;i<400;i++){
      countArr[i]=0;
  }
  // 遍历所有的数,
  for(var i=0;i<100000;i++){
      arr[i]=parseInt(Math.random()*400+100);
      countArr[arr[i]-100]++;
  }

6.耶稣有13个门徒,其中有一个就是出卖耶稣的叛徒,请用排除法找出这位叛徒:13人围坐一圈,从第一个开始报号:1,2,3,1,2,3凡是报到“3”就退出圈子,最后留在圈子内的人就是出卖耶稣的叛徒

    var count = 0;
    var arr = [1,1,1,1,1,1,1,1,1,1,1,1,1];
    var p = 0;
  for(var i = 0; i < arr.length; i++){
        // 只有当内容为1的人才可以报数+,内容为0代表已经出圈,不可以报数。
        if (arr[i]!=0) {
            // 报数,+1
            count++;// 报数为4的时候,要变为1。123123123
        
        if (count ==  4){
            count = 1;
        }
        // 报数为3的人,会被踢出圈子。踢出圈子的人内容要标记为0;
        if (count == 3) {
            arr[i] = 0;
            // 每出圈一个人记录。只剩最后一个人的时候退出循环。
            p++;
            if (p == arr.length - 1) {
                break;
            }
        }
    }
        // 报数进行到最后一个人的时候,要回到第一个人继续报数。
        if (arr.length - 1 == i) {
            i = -1;
        }
    }
         console.log(arr);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容