猜密码:小杨申请了一个保密柜,但是他忘记了密码。只记得密码都是数字,而且所有数字都是不重复的。

题目

小杨申请了一个保密柜,但是他忘记了密码。只记得密码都是数字,而且所有数字都是不重复的。

请你根据他记住的数字范围和密码的最小数字数量,帮他算下有哪些可能的组合,

规则如下:

1.输出的组合都是从可选的数字范围中选取的,且不能重复;
2.输出的密码数字要按照从小到大的顺序排列,密码组合需要按照字母顺序,从小到大的顺序排序。
3.输出的每一个组合的数字的数量要大于等于密码最小数字数量;
4.如果可能的组合为空,则返回“None"

输入描述.
1.输入的第一-行是可能的密码数字列表,数字间以半角逗号分隔
2.输入的第二行是密码最小数字数量

输出描述: .
可能的密码组合,每种组合显示成一行,每个组合内部的数字以半角逗号分隔,从小到大的顺序排
输出的组合间需要按照字典序排序Q。
比如:
2,3,4放到2,4的前面.

补充说明
箱子中字符拼出的字符串与密码的匹配忽略大小写,且要求与密码完全匹配,如密码abc匹配aBc,但是密码abc不匹配abcd

示例一
输入

2,34

输出

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);//回溯,从当前组合中移除最后一个添加的元素,即回退到之前的状态。
        }
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

STRUGGLE_xlf

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值