算法题之遐想

[b]今天一同事问到了这个题目,想了一个算法,记录以作备忘[/b]

/**
* 算法题:{3,2,2,6,7,8},这是一个排列,其中7不能放在第二个位置,6和8不能相邻,打印所有的排列
*
* @param args
* @author jeck218@gmail.com 2009-10-12
*/
public static void main(String[] args) {
//{3,2,2,6,7,8},其中7不能放在第二个位置,6和8不能相邻,打印所有的排列

List<String> list = new ArrayList<String>();
for (int i = 223678; i <= 876322; i++)
list.add(i + "");

int size = 0;// all size

for (String s : list) {
if (s.indexOf("0") != -1
|| s.indexOf("1") != -1
|| s.indexOf("4") != -1
|| s.indexOf("5") != -1
|| s.indexOf("9") != -1)// except 0,1,4,5,9
continue;

if (s.indexOf("2") == -1
|| s.indexOf("3") == -1
|| s.indexOf("6") == -1
|| s.indexOf("7") == -1
|| s.indexOf("8") == -1
|| s.indexOf("2", s.indexOf("2") + 1) == -1)// contain all 3,2,2,6,7,8
continue;

if (s.indexOf("7") == 1)// except 7 in second position
continue;

if (s.indexOf("68") != -1 || s.indexOf("86") != -1)// except adjoining 6,8
continue;

size++;

System.out.println(s);
}

System.out.println("All size --> " + size);// All size --> 198
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值