文档章节

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

w
 waterme
发布于 2016/07/09 23:28
字数 608
阅读 0
收藏 0

随机给定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>


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

 

 


本文转载自:http://blog.csdn.net/feihongxueni/article/details/48317121

w
粉丝 0
博文 27
码字总数 0
作品 0
海淀
私信 提问
由两个n位数相乘得到的最大回文 Largest Palindrome Product

问题: Find the largest palindrome made from the product of two n-digit numbers. Since the result could be very large, you should return the largest palindrome mod 1337. Example......

叶枫啦啦
2018/01/06
0
0
LeetCode算法题-Nth Digit(Java实现)

这是悦乐书的第215次更新,第228篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第83题(顺位题号是400)。找到无限整数序列的第n个数字1,2,3,4,5,6,7,8,9,10,11 ......例如:...

小川94
2018/12/28
0
0
美团2012研发工程师笔试题(数数字问题)

原题 source=group.jobbole.com&utmmedium=relatedTopics> 从1到1000000的所有自然数,数字“1”一共出现了多少次?例:自然数101中,数字“1”出现了2次,自然数1011中,数字“1”出现了3次...

m2012
2016/02/01
124
0
【语法篇】5、for循环(二)

一、筛选 在现实生活中,处处存在竞争和筛选,古代人们从沙砾中淘金,也是一种筛选。所谓筛选,就是在某个范围内,将符合某种特定条件的东西遴选出来的过程。筛选在编程中也有非常广泛的应用...

沧海无雨
2017/09/26
0
0
罗马数字的构造规则

罗马数字 罗马数字是古罗马时期的计数系统,也是最早的数字表示方式,多用于钟表、日历和章节编号。一般认为,罗马数字只用来计数而不作演算。像II,IV,VII,这些都是常见的罗马数字。 构造...

testglory
2017/05/14
0
0

没有更多内容

加载失败,请刷新页面

加载更多

GMTC2019|闲鱼-基于Flutter的架构演进与创新

作者:闲鱼技术-宗心 2012年应届毕业加入阿里巴巴,主导了闲鱼基于Flutter的新混合架构,同时推进了Flutter在闲鱼各业务线的落地。未来将持续关注终端技术的演变及趋势 Flutter的优势与挑战 ...

阿里云云栖社区
18分钟前
2
0
迪蒙人工智能共享停车吸引国际关注

  近来,华为创始人任正非多次提及人工智能。即便在华为生死攸关的关键时刻,任正非依旧不忘强调教育的重要性,“如果不重视教育,实际上我们会重返贫穷的,因为这个社会,最终是要走向人工智能的...

琴殇的
19分钟前
0
0
iOS开发之EventKitUI框架的应用

iOS开发之EventKitUI框架的应用 前面博客,有介绍EventKit这个框架的使用,使用EventKit可以与系统的日历和提醒应用进行交互,读写用户的日程事件。EventKitUI,顾名思义,其实基于EventKit框...

珲少
27分钟前
0
0
从MySQL源码看其网络IO模型

从MySQL源码看其网络IO模型 前言 MySQL是当今最流行的开源数据库,阅读其源码是一件大有裨益的事情(虽然其代码感觉比较凌乱)。而笔者阅读一个Server源码的习惯就是先从其网络IO模型看起。于是...

无毁的湖光-Al
28分钟前
0
0
WebService学习笔记

什么是Web Services? Web Services 是应用程序组件 Web Services 使用开放协议进行通信 Web Services 是独立的(self-contained)并可自我描述 Web Services 可通过使用UDDI来发现 Web Serv...

榴莲黑芝麻糊
44分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部