1、2、2、3、4、5這六個數字,用java寫一個main函數,打印出所有不同的排列, 如:512234、412345等.要求:"4"不能在第三位,"3"與"5"不能相連.

package cn.ls.lanqiao;

public class Test {
	private static String[] ls = { "1", "2", "2", "3", "4", "5" };

	public static void main(String[] args) {
		int sum = 0;
		for (int i = 122345; i < 543221; i++) {

			if (isValidNumber(Integer.toString(i))) {
				sum++;
				System.out.println(i);

			}

		}
		System.out.println("一共有" + sum + "種不同的排列");
	}

	private static boolean isValidNumber(String str) {

		// 檢查是否包含12345這五個數,不包含返回false

		for (String number : ls) {

			if (str.indexOf(number) < 0)

				return false;

		}

		// 檢查是否有兩個2,只有一個返回false

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

			return false;

		}

		// 檢查4在不在第三位,是返回false

		if (str.charAt(2) == '4') {

			return false;

		}

		// 檢查是否存在35在一起,有返回false

		if (str.indexOf("35") >= 0 || str.indexOf("53") >= 0) {

			return false;

		}

		return true;

	}
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章