java 打印 排序 数字塔_java算法之打印数字的组合顺序

题目:用1、2、2、3、4、5这6个数字组成一个序列,列出所有可能出现的顺序。

要求:

1. 数字4不能位于第三位

2.3和5不能连在一起

今天上网看到一个好的解决思路,整理如下:

代码:

public class Test{

static int[] in={1,2,2,3,4,5};

public static void main(Strin[] args){

for(int i = 122345;i<=543221;i++){

String string = String.valueOf(i);

if(checkOne(string) && checkTwo(string)

&& checkThree(string)

&& checkFour(string)){

System.out.println(string);

}

}

}

/**

* 不包含0,6,7,8,9

* @author zkf

* @createTime 2013-7-20

* @param str

* @return boolean

*/

public static boolean checkOne(String str){

Pattern p = Pattern.compile("[0[6-9]]");

Matcher matcher = p.matcher(str);

matcher.matches();

if(matcher.find()){

return false;

}

return true;

}

/**

* 必须是1,2,2,3,4,5六个数

* @author zkf

* @createTime 2013-7-20

* @param str

* @return boolean

*/

public static boolean checkTwo(String str){

for (int i = 0; i < in.length; i++) {

if(!str.contains(String.valueOf(in[i]))){

return false;

}

}

if(str.indexOf("2") == str.lastIndexOf("2")){

return false;

}

return true;

}

/**

*4不能位于第3位

* @author zkf

* @createTime 2013-7-20

* @param str

* @return boolean

*/

public static boolean checkThree(String str){

if(str.indexOf("4") == 2){

return false;

}

return true;

}

/**

*35不能相连

* @author zhangkefei

* @createTime 2013-7-20

* @param str

* @return boolean

*/

public static boolean checkFour(String str){

if(Math.abs(str.indexOf("3")-str.indexOf("5")) == 1){

return false;

}

return true;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值