隨機給定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>
總結:方法二思路較爲簡單,只需多加註意註釋內容即可