思路:把这些数随机放入一个数组,然后判断一下下标为2的元素是不是4,再判断一下有没有两个相邻下标的元素是4跟5,再判断这个数组是否出现过.都判断通过了那么这就是一种,这时候计数自加一次.反复循环.
dd
循环遍历122345-543221 符合条件的打印
public static void main(String[] args) {
// TODO Auto-generated method stub
int su[]={1,2,2,3,4,5};
for(int i=122345;i<543221;i++){
char s[]=new Integer(i).toString().toCharArray();
int s1=0;int s2=0;int s3=0;int s4=0;int s5=0;boolean flag=true;
for(int j=0;j<s.length;j++){
if(s[j]=='1'){s1++;}
if(s[j]=='2'){s2++;}
if(s[j]=='3'){s3++;}
if(s[j]=='4'){s4++;}
if(s[j]=='5'){s5++;}
if(j!=s.length-1)
{
if(s[j]=='3'&&s[j+1]=='5'||s[j]=='5'&&s[j+1]=='3'){
flag=false;
}
}
}
if(s[2]=='4'){
flag=false;
}
if(s1==1&&s2==2&&s3==1&&s4==1&&s5==1&&flag){
System.out.println(i);
}
}
}
把122345当做整数递增循环,所以不会有把2当做不同的数,上述方法效率较低。要遍历很多不必要的数。