一道算法题求解

发布于 2022-09-12 23:01:47 字数 190 浏览 14 评论 0

给定一个正整数数组a,以及一个目标数字x,使用你最熟悉的语言,编写一个函数,找出数组中所有可以使数字之和等于x的组合g(组合不能重复)。注:数组中的数字可以无限制被重复选取。

例如:a = [2,3,5,6,8],x = 8,g = [[2,2,2,2], [2,3,3], [2,6], [8], [3,5]]

用golang或者php解答

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

沫离伤花 2022-09-19 23:01:47

其实这里可以用到递归 ,大致的思路

  1. 排序数组
  2. 从左抽取数组元素,让目标数字去减,形成新的目标数,这样去递归
  3. 找出所有涉及该元素的组合
  4. 抽取指针移动,后续抽取和组合中均不涉及该元素(这样保证不重复)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文