免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 14794 | 回复: 10
打印 上一主题 下一主题

怎么求出N个数字中哪几个数字相加等于15(某个定值) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-04-19 11:02 |只看该作者 |倒序浏览
比如说我有30个数
1
2
3
4
。。。
29
30

哪几个数字相加等于15?

最号能是优化点的算法

论坛徽章:
0
2 [报告]
发表于 2012-04-19 11:07 |只看该作者
本帖最后由 dahaoshanhe 于 2012-04-19 11:11 编辑


    还要优化的 你的要求真高  我的不算优化
  1. more file
  2. 1
  3. 2
  4. 3
  5. 4
  6. 5
  7. 6
  8. 7
  9. 8
  10. 12
  11. 5
  12. 6
  13. 7
  14. 8
  15. 9
  16. 6
  17. 29
  18. 30
  19. awk '{printf $1 " "}' file > f2
  20. awk -f ak f2
  21. more ak
  22. {
  23. for(i=1;i<NF;i++)
  24.    {
  25.      for(j=2;j<=NF;j++)
  26.        {
  27.          if(i+j==15)
  28.            {
  29.              print i,j
  30.            }
  31.        }
  32.     }
  33. }
复制代码
回复 1# lasse


论坛徽章:
0
3 [报告]
发表于 2012-04-19 11:13 |只看该作者
本帖最后由 personball 于 2012-04-19 11:24 编辑

比较考算法的。。。

按我理解的,lz需要从某个数字集合中取出一个数字组合s,对其求和sum等于指定值

我给个笨点的:

1.首先排序n个数字集合Set(n);
2.(求数字组合s1)取首个数字x1,与定值N1比较,如果x1>N1,s1失败[不可包含x1];如果x1=N1,返回x1;如果x1<N1,计算x1与N1差值N2,以剩余的数字集合S(n-1)和定值N2,迭代上述过程直到xn>=Nn

效率什么的,这个算很低吧 - -。
貌似求出来的解也不全。。。数学忘光了

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
4 [报告]
发表于 2012-04-19 11:17 |只看该作者
1+1+1+1+1+1+1+1+1+1+1+1+1+1+1=15

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
5 [报告]
发表于 2012-04-19 11:30 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
6 [报告]
发表于 2012-04-19 12:32 |只看该作者
给个参考。
http://www.dewen.org/q/674

论坛徽章:
0
7 [报告]
发表于 2012-04-19 12:42 |只看该作者
发错版了

论坛徽章:
0
8 [报告]
发表于 2012-04-19 14:44 |只看该作者
回复 3# personball


    不一定是两个数相加,需要列出所有多数相加为定值的组合。。

论坛徽章:
0
9 [报告]
发表于 2012-04-19 15:19 |只看该作者
回复 8# lasse


    哎,你要是理解我写的东西,就不会说是两数相加了。。。
N=x1+N1
N1=X2+N2
......

N=x1+x2+x3+...+xn

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
10 [报告]
发表于 2012-04-19 15:36 |只看该作者
回复 1# lasse


    在某个算法书上看过,你找下算法有关的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP