已知有1, 2, 3, 4 这四个数字, 问它们能组合成的四位数字形式有哪些, 并将结果打印到控制台上.
要求: 该四位数字必须包含1, 2, 3, 4 这四个数字.
需求1: 将满足上述条件的数字, 按照3个一行的顺序打印到控制台上, 例如:
//这里只是模拟打印格式, 不一定非得是这种打印顺序。
格式:
1234 1243 1324
1432 …
需求2: 基于上述的要求, 加入如下的条件
1. 数字4不能开头.
2. 数字1和3不能挨着, 即: 2134 和 2314都不行.
3. 将满足条件的数据按照 5 个一行的顺序, 打印到控制台上.
需求3: 要求5行以内搞定.
方案一:(无法完成需求三)
public class Demo { public static void main(String[] args) { //计数 int count=0; //不能以4开头 for (int i = 1; i < 4; i++) { for (int j = 1; j <= 4; j++) { //保证数字不重复使用 if (j == i) continue; //保证1和3不相邻 if ((i == 1 && j == 3) || (i == 3 && j == 1)) continue; for (int k = 1; k <= 4; k++) { //保证数字不重复使用 if (k == j || k == i) continue; //保证1和3不相邻 if ((j == 1 && k == 3) || (j == 3 && k == 1)) continue; for (int l = 1; l <= 4; l++) { //保证数字不重复使用 if (l == i || l == j || l == k) continue; //保证1和3不相邻 if ((k == 1 && l == 3) || (k == 3 && l == 1)) continue; System.out.print("" + i + j + k + l + "\t"); //每行显示五个 if((++count)%3==0) System.out.println(); } } } } } }
方案二:
public class Demo8 { public static void main(String[] args) { //四种数字最小排列为1234,最大排列为4321 //定义count用于计数,每3个一行 for (int i = 1234, count = 0; i <= 4321; i++) { //将数字转换成字符串 String str = i + ""; //str.contains("1") && str.contains("2") && str.contains("3") && str.contains("4")必须确保数据同时存在1234, //!str.contains("4") 数字4不能开头. //!str.contains("13") && !str.contains("31")数字1和3不能挨着 if (str.contains("1") && str.contains("2") && str.contains("3") && str.contains("4") && !str.startsWith("4") && !str.contains("13") && !str.contains("31")) //使用++和三目运算符操作实现换行输出 System.out.print(i + (++count % 3 == 0 ? "\r\n" : "\t")); } } }