目录
- 一、题目描述
- 二、输入描述
- 三、输出描述
- 四、解题思路
- 五、Java算法源码
- 六、效果展示
- 1、输入
- 2、输出
- 3、说明
华为OD机试 2023B卷题库疯狂收录中,刷题点这里
一、题目描述
给定一个整数数组nums、一个数字k,一个整数目标值target,请问nums中是否存在k个元素,使其相加结果为target,请输出所有符合条件且不重复的k元组的个数。
取值范围:
2 <= nums.length <= 200
-109 < numslil < 109
-109 < target< 109
2 <= k <= 100
二、输入描述
第一行输入整数数组nums;
第二行输入数字k;
第三行输入整数目标值target;
三、输出描述
输出第一行是符合要求的元组个数。
四、解题思路
- 输入整数数组nums;
- 输入数字k;
- 输入整数目标值target;
- 递归计算数组nums中是否有k个数字之和等于target,并且组合不能重复;
- 输出符合条件的数量okSum;
五、Java算法源码
// 符合条件的数量
public static int okSum = 0;
public static int target;
public static List<List<Integer>> numsList = new ArrayList<>();/*** 从nums数组中取k个数,使其和等于target*/
public static void main(String[] args) {Scanner sc = new Scanner(System.in);// 整数数组numsint[] nums = Arrays.stream(sc.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();// 输入数字kint k = sc.nextInt();// 输入整数目标值targettarget = sc.nextInt();calculate(nums, k, new ArrayList<>(), 0);System.out.println(okSum);
}/*** @param nums 数组* @param n n个数* @param list 选取的数字* @param index 数组的索引*/
public static void calculate(int[] nums, int n, List<Integer> list, int index) {if (n == 0) {int count = 0;// 集合内数字之和for (Integer i : list) {count += i;}// 符合条件且不重复if (count == target && !isContains(list)) {numsList.add(new ArrayList<>(list));okSum++;}} else {for (int i = index; i < nums.length; i++) {list.add(nums[i]);calculate(nums, n - 1, list, i + 1);list.remove(list.size() - 1);}}
}/*** 集合是否重复*/
public static boolean isContains(List<Integer> list) {Collections.sort(list);for (List<Integer> temp : numsList) {Collections.sort(temp);if (list.size() == temp.size()) {if (list.containsAll(temp)) {return true;}}}return false;
}
六、效果展示
1、输入
1 2 5 8 4
2
9
2、输出
2
3、说明
[1,8],[5,4]满足条件。
🏆下一篇:华为OD机试真题 Java 实现【简易内存池】【2023 B卷 200分 考生抽中题】
🏆本文收录于,华为OD机试(JAVA)真题(A卷+B卷)
刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。