Bootstrap

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

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

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

//方法一:

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

if(m ==0 ) endmax = b[0];

if(m!=0 && endmax < b[m]) endmax = b[m];

}

return endmax;

}

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

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

//方法二:

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];

}

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

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;