java入门#每天一个小程序#全排列
2016-09-12 10:33
323 查看
初学java,还没弄明白递归排序,只会用一个小程序写出字符很少的全排列。
当有3个字符时,需要3级for循环,表达出来会有3*2*1=6种全排列方式;当有4个字符时,需要4级for循环,表达出来有4*3*2*1种全排列方式,依次类推。所以,如果字符很多的时候,for循环等的次数也会变多,此小程序并不适用。
代码如下:
public class arrangement{
public static void main(String[] args){
char[] arr=new char[] {'w','o','r','d'};
int i,j,k,m;
for(i=0;i<arr.length;i++){
for (j=0;j<arr.length;j++){
for(k=0;k<arr.length;k++){
for(m=0;m<arr.length;m++){
if(i!=j&&i!=k&&i!=m&&j!=k&&j!=m&&k!=m)//互不相等
System.out.println(arr[i]+""+arr[j]+""+arr[k]+""+arr[m]);//注意一下输出的方式
}
}
}
}
}
}
结果如下:
学会了递归之后,等我补充,哈哈
当有3个字符时,需要3级for循环,表达出来会有3*2*1=6种全排列方式;当有4个字符时,需要4级for循环,表达出来有4*3*2*1种全排列方式,依次类推。所以,如果字符很多的时候,for循环等的次数也会变多,此小程序并不适用。
代码如下:
public class arrangement{
public static void main(String[] args){
char[] arr=new char[] {'w','o','r','d'};
int i,j,k,m;
for(i=0;i<arr.length;i++){
for (j=0;j<arr.length;j++){
for(k=0;k<arr.length;k++){
for(m=0;m<arr.length;m++){
if(i!=j&&i!=k&&i!=m&&j!=k&&j!=m&&k!=m)//互不相等
System.out.println(arr[i]+""+arr[j]+""+arr[k]+""+arr[m]);//注意一下输出的方式
}
}
}
}
}
}
结果如下:
学会了递归之后,等我补充,哈哈
相关文章推荐
- java入门#每天一个小程序#九九乘法
- 2013年用友校招编程题:用1、2、2、3、4、5这六个数字,用java写一个程序,打印出所有不同的排列
- 用1、2、3、3、4、5这六个数字,用java写一个程序,打印出所有不同的排列 要求:"4"不能在第三位,"3"与"5"不能相连。
- 每天一个java小程序-4
- 每天一个java小程序-8
- 从奥特曼和小怪兽的决斗中分析java类和对象-初学者必须会的一个入门程序
- java练习题,每天一个java小程序-1…
- java练习题,每天一个java小程序-13
- 每天一个java小程序-6
- 每天一个java小程序-7
- 每天一个java小程序
- 每天一个java小程序-6
- 每天一个java小程序-2
- java练习题,每天一个java小程序-1…
- 2. 编写一个Java应用程序,用户从键盘输入一个1~9999之间的数,程序将判断这个数是几位数,并判断这个数是否是回文数。回文数是指将该数含有的数字逆序排列后得到的数和原数相同,例如12121、32
- 每天一个java小程序-5
- java练习题,每天一个java小程序-1…
- java练习题,每天一个java小程序-1…
- 每天一个java小程序-3
- 每天一个java小程序-4