java趣味问题--> 题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
packageText_11;publicclassText_11{publicstaticvoidmain(String[]args){inta,b,c,i,j,k,n...
package Text_11;
public class Text_11 {
public static void main(String[] args) {
int a,b,c,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++){
if (i!=k&&j!=k){
n=i*100+j*10+k;
s[i]=n;
System.out.print(s[i]+" ");
count++;
}
}
}
}
}
System.out.println(count);
for (i=1;i<=count;i++){
System.out.print(s[i]+" ");
}
}
}
为何我打印的俩次是s[i]数组。。出来的数字结果不一样。
打印结果为:
123 132 142 143 213 231 241 243 312 321 341 342 412 413 421 423 431 432 18
143 243 342 432 0 0 0 0 0 0 0 0 0 0 0 0 0 0 展开
public class Text_11 {
public static void main(String[] args) {
int a,b,c,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++){
if (i!=k&&j!=k){
n=i*100+j*10+k;
s[i]=n;
System.out.print(s[i]+" ");
count++;
}
}
}
}
}
System.out.println(count);
for (i=1;i<=count;i++){
System.out.print(s[i]+" ");
}
}
}
为何我打印的俩次是s[i]数组。。出来的数字结果不一样。
打印结果为:
123 132 142 143 213 231 241 243 312 321 341 342 412 413 421 423 431 432 18
143 243 342 432 0 0 0 0 0 0 0 0 0 0 0 0 0 0 展开
2个回答
展开全部
存放结果的数组下标不能用变量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]+" ");
}
}
}
这是我修改了的版本,修改了的地方给了注释
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]+" ");
}
}
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询