随机给定10个小于10的数字(出现的数字可能重复),从其中取出3个各不相同的数字可组合出多个不同的3位数,请输出这些3位数中最大的那个3位数

随机给定10个小于10的数字(出现的数字可能重复),从其中取出3个各不相同的数字可组合出多个不同的3位数,请输出这些3位数中最大的那个3位数

方法一思路:找出10个数中不重复的3个数,取出这三个数组合后的最大值保存到数组中,之后从保存的数组中查找最大值

<script>
//方法一:
 function getmax(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9){
    var arr = [n0,n1,n2,n3,n4,n5,n6,n7,n8,n9];
    var newarr = [];
    var b = [];
    var endmax = 0;
    for (i = 0; i < arr.length; i++) {
        for (j = 0; j < arr.length; j++) {
            if (arr[i] == arr[j]) continue;
            for (k = 0; k < arr.length; k++) {
                if (arr[k] == arr[i] || arr[k] == arr[j]) continue;
                //console.log(arr[k],arr[i],arr[j]);
                newarr = [];
                newarr = [arr[i],arr[j],arr[k]];
                
                var max =0;var centernum;
                max = arr[i] > arr[j] ? arr[i] : arr[j];
                max = max > arr[k] ? max : arr[k];
                min = arr[i] < arr[j] ? arr[i] : arr[j];
                min = min < arr[k] ? min : arr[k];
                for(var c=0;c<3;c++){
                    if(newarr[c] < max && newarr[c] > min) {
                        centernum = newarr[c];
                        break;
                    }
                }
                b.push(max*100+centernum*10+min);
                
            }   
        }   
    }
    for(var m = 0;m<b.length;m++){
        if(m ==0 )  endmax  = b[0];
        if(m!=0 && endmax < b[m]) endmax = b[m];
    }   
    return endmax;
 }
</script>

随机给定10个小于10的数字(出现的数字可能重复),从其中取出3个各不相同的数字可组合出多个不同的3位数,请输出这些3位数中最大的那个3位数

方法二思路:循环查找出这十个数中的最大值,将其存到数组中,然后组合即为最大值

<script>
//方法二:
 function getmax3(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9){
     var arr = [n0,n1,n2,n3,n4,n5,n6,n7,n8,n9];
     var max = 0;
     var maxarr = [];
    
     //获取最大数
     for(var c = 0;c<3;c++){
        if(c != 0){
           max = 0;//下次循环开始要清空max的值
            for(var j = 0;j < arr.length;j++){
                var flag = 0;
                for(var m = 0;m < maxarr.length;m++){
                    if(arr[j] == maxarr[m]) flag=1;//当前值是否是已存在的最大值
                }
                if(!flag){
                    if(arr[j] > max) max = arr[j];
                }
                
            }   
            
            maxarr.push(max);
            
        }else{
             for(var i = 0;i < arr.length;i++){
           
                if(arr[i] > max) max = arr[i];
            }
            maxarr.push(max);

        }
    }
    return maxarr[0]*100+maxarr[1]*10+maxarr[2];
     
 }


</script>


总结:方法二思路较为简单,只需多加注意注释内容即可

 

 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值