一、题目描述
小杨申请了一个保密柜,但是他忘记了密码。只记得密码都是数字,而且所有数字都是不重复的。
请你根据他记住的数字范围和密码的最小数字数量,帮他算下有哪些可能的组合,规则如下:
- 输出的组合都是从可选的数字范围中选取的,且不能重复;
- 输出的密码数字要按照,从小到大的顺序排列,密码组合需要按照字母顺序,从小到大的顺序排序;
- 输出的每一个组合的数字的数量要大于等于密码最小数字数量;
- 如果可能的组合为空,则返回“None”
二、输入描述
第一行是可能的密码数字列表,数字间以半角逗号分隔;
第二行是密码最小数字数量。
三、输出描述
可能的密码组合,每种组合显示成一行,每个组合内部的数字以半角逗号分隔,从小到大的顺序排列。
输出的组合间需要按照字典序排序。
四、测试用例
测试用例1
1、输入
1,3,2
2
2、输出
1,2
1,2,3
1,3
2,3
3、说明
输入数字顺序混乱,但经过排序后为1,2,3,然后组合输出。
这篇博客介绍了华为OD机试中的一道猜密码问题,使用深度优先搜索(DFS)算法来解决。题目要求从给定数字范围内找出所有不重复的数字组合,满足指定的最小数字数量并按升序排列。博客详细阐述了解题思路、Java算法源码以及效果展示,帮助读者理解DFS的应用。
订阅专栏 解锁全文
2618

被折叠的 条评论
为什么被折叠?



