题目
小杨申请了一个保密柜,但是他忘记了密码。只记得密码都是数字,而且所有数字都是不重复的。
请你根据他记住的数字范围和密码的最小数字数量,帮他算下有哪些可能的组合,
规则如下:
1.输出的组合都是从可选的数字范围中选取的,且不能重复;
2.输出的密码数字要按照从小到大的顺序排列,密码组合需要按照字母顺序,从小到大的顺序排序。
3.输出的每一个组合的数字的数量要大于等于密码最小数字数量;
4.如果可能的组合为空,则返回“None"
输入描述.
1.输入的第一-行是可能的密码数字列表,数字间以半角逗号分隔
2.输入的第二行是密码最小数字数量
输出描述: .
可能的密码组合,每种组合显示成一行,每个组合内部的数字以半角逗号分隔,从小到大的顺序排
输出的组合间需要按照字典序排序Q。
比如:
2,3,4放到2,4的前面.
补充说明
箱子中字符拼出的字符串与密码的匹配忽略大小写,且要求与密码完全匹配,如密码abc匹配aBc,但是密码abc不匹配abcd
示例一
输入
2,3,4
输出
2,3
2,3,4
2,4
3,4
Java代码
package day11;
import java.util.*;
public class passwordGuessing {
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String[] numStrings = sc.nextLine().split(",");
int n = Integer.parseInt(sc.nextLine());//最小数字数量
List<List<Integer>> combinations = new ArrayList<>();
Arrays.sort(numStrings);//对数字列表进行排序
for(int i = n; i <=numStrings.length;i++){
generateCombinations(numStrings,i,0,new ArrayList<>(),combinations);
}
Collections.sort(combinations,(a,b)->{
for(int i=0;i<Math.min(a.size(),b.size());i++){
int compareResult = Integer.compare(a.get(i),b.get(i));
if(compareResult !=0){
return compareResult;
}
}
return Integer.compare(a.size(),b.size());
});
if(!combinations.isEmpty()){
for(List<Integer> combination:combinations){
StringBuilder sb = new StringBuilder();
for(int num:combination){
sb.append(num).append(",");
}
String combinationString = sb.toString();
System.out.println(combinationString.substring(0,combinationString.length()-1));
}
}else{
System.out.println("None");
}
}
private static void generateCombinations(String[] numString,int k,int start,List<Integer> current,List<List<Integer>> combinations){
if(k==0){
combinations.add(new ArrayList<>(current));
return;
}
for(int i=start;i<=numString.length-k;i++){
current.add(Integer.parseInt(numString[i]));
generateCombinations(numString,k-1,i+1,current,combinations);
current.remove(current.size()-1);//回溯,从当前组合中移除最后一个添加的元素,即回退到之前的状态。
}
}
}