内容简介:Find all possible combinations of k numbers that add up to a number n, given that only numbers from 1 to 9 can be used and each combination should be a unique set of numbers.Note:All numbers will be positive integers.
Find all possible combinations of k numbers that add up to a number n, given that only numbers from 1 to 9 can be used and each combination should be a unique set of numbers.
Note:
All numbers will be positive integers.
The solution set must not contain duplicate combinations.
Example 1:
Input: k = 3, n = 7 Output: [[1,2,4]]
Example 2:
Input: k = 3, n = 9 Output: [[1,2,6], [1,3,5], [2,3,4]]
难度:medium
题目:找出所有可能的K个数之和为n的组合,只可以使用1到9之间的数。
注意:所有数都为正,给出的答案中不包含重复的数。
思路:递归
Runtime: 1 ms, faster than 66.65% of Java online submissions for Combination Sum III.
Memory Usage: 35 MB, less than 54.02% of Java online submissions for Combination Sum III.
class Solution { public List<List<Integer>> combinationSum3(int k, int n) { List<List<Integer>> result = new ArrayList<>(); if (n > 45 || n < 1 || k < 1 || k > 9) { return result; } combination(1, k, 0, n, new Stack<>(), result); return result; } private void combination(int begin, int k, int sum, int n, Stack<Integer> stack, List<List<Integer>> result) { if (k < 0 || sum > n) { return; } if (0 == k && sum == n) { result.add(new ArrayList<>(stack)); return; } for (int i = begin; i <= 9 - k + 1; i++) { stack.push(i); combination(i + 1, k - 1, sum + i, n, stack, result); stack.pop(); } } }
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Java遗传算法编程
Lee Jacobson、Burak Kanber / 王海鹏 / 人民邮电出版社 / 2016-12-6 / 49元
本书简单、直接地介绍了遗传算法,并且针对所讨论的示例问题,给出了Java代码的算法实现。全书共分灾6章。第1章简单介绍了人工智能和生物进化的知识背景,这也是遗传算法的历史知识背景。第2章给出了一个基本遗传算法的实现;第4章和第5章,分别针对机器人控制器、旅行商问题、排课问题展开分析和讨论,并给出了算法实现。在这些章的末尾,还给出了一些练习供读者深入学习和实践。第6章专门讨论了各种算法的优化问题。 ......一起来看看 《Java遗传算法编程》 这本书的介绍吧!