java趣味问题--> 题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?

2024-11-22 11:55:10
推荐回答(2个)
回答(1):

存放结果的数组下标不能用变量i ,因为变量i只从1变化到4, 这样做的话只存放了4条结果,因为, 后面满足条件的结果会把前面满足条件的覆盖掉。

这是我修改了的版本,修改了的地方给了注释
public class Text_11 {
public static void main(String[] args) {

int i,j,k,n,count=0;
int s[]=new int [100];
for (i=1;i<=4;i++){
for (j=1;j<=4;j++){
if (i!=j){
for (k=1;k<=4;k++){ //k值也可以等于4
if (i!=k&&j!=k){
n=i*100+j*10+k;
s[count]=n; //数组下标改为count
System.out.print(s[count]+" ");
count++;
}

}
}
}
}
System.out.println(count);
for (i=0;i<=count;i++){ //i从零开始增加
System.out.print(s[i]+" ");
}

}

}

回答(2):

这个逻辑有点问题,里面那层,组合的数不能赋值给s[i],因为i只有1到4四个值,这样,下一种结果s[i]就把上一种结果s[i]覆盖了(当i没有变化,j,k在变化时)。
所以这个地方s[i]=n;
System.out.print(s[i]+" ");
count++;
可以改成
count++;
s[count]=n;
System.out.print(s[count]+" ");