免费注册 查看新帖 |

Chinaunix

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

[C] 算数问题,请问C代码怎么写。谢谢 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-02 17:28 |只看该作者 |倒序浏览

请问用C 怎么写出如图的测试代码?
各位大大!

论坛徽章:
1
摩羯座
日期:2013-12-19 10:04:07
2 [报告]
发表于 2013-05-02 17:33 |只看该作者
1~9做全排列 然后
判断同时满足两条等式的 输出 完事

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
3 [报告]
发表于 2013-05-03 09:44 |只看该作者
跟据2楼描述写出的C++代码
  1. #include <iostream>
  2. #include <iterator>
  3. #include <algorithm>

  4. int main()
  5. {
  6.     unsigned buf[9] = { 1,2,3,4,5,6,7,8,9 };
  7.     do
  8.     {
  9.         if( (buf[0]*10+buf[1])*buf[2]==(buf[3]*10+buf[4])
  10.             && (buf[3]*10+buf[4])+(buf[5]*10+buf[6])==(buf[7]*10+buf[8]) )
  11.         {
  12.             std::copy( buf+0,buf+9, std::ostream_iterator<unsigned>(std::cout,"") );
  13.             std::cout << "\n";
  14.         }
  15.     }
  16.     while( std::next_permutation(buf+0,buf+9) );
  17.    
  18.     return 0;
  19. }
复制代码

论坛徽章:
0
4 [报告]
发表于 2013-05-03 13:15 |只看该作者
谢谢了!!!回复 3# bruceteen


   

论坛徽章:
0
5 [报告]
发表于 2013-05-03 15:03 |只看该作者
楼主要是不想用c++的算法库,可以自己用动态规划写一个,算法也很简单

  1. #include <stdio.h>

  2. void dp(int *a, int *b, int n)
  3. {
  4.         int i;
  5.        
  6.         if (n==9) {
  7.                 if ((b[0]*10+b[1])*b[2]==(b[3]*10+b[4])
  8.             && (b[3]*10+b[4])+(b[5]*10+b[6])==(b[7]*10+b[8])) {
  9.                     printf("(%d%d * %d = %d%d) + %d%d = %d%d",
  10.                                         b[0], b[1], b[2], b[3] ,b[4], b[5], b[6], b[7], b[8]);
  11.             }
  12.                 return ;
  13.         }
  14.        
  15.         for (i=0; i<9; i++) {
  16.                 if (a[i] != 0) {
  17.                         b[n] = a[i];
  18.                         a[i] = 0;
  19.                         dp(a, b, n+1);
  20.                         a[i] = b[n];
  21.                 }
  22.         }
  23. }

  24. int main()
  25. {
  26.         int a[9] = {1, 2, 3, 4, 5, 6, 7, 8, 9};
  27.         int b[9];
  28.        
  29.         dp(a, b, 0);
  30.        
  31.         return 0;               
  32. }
复制代码

论坛徽章:
0
6 [报告]
发表于 2013-05-03 21:19 |只看该作者
netcos 发表于 2013-05-03 15:03
楼主要是不想用c++的算法库,可以自己用动态规划写一个,算法也很简单

这个代码很牛逼,看了好久才看明白。膜拜一下大神!

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
7 [报告]
发表于 2013-05-06 19:25 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
8 [报告]
发表于 2013-05-06 21:30 |只看该作者
回复 7# pmerofc


    怎么加??

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
9 [报告]
发表于 2013-05-07 06:49 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
10 [报告]
发表于 2013-05-07 10:21 |只看该作者
回复 5# netcos


    这是不是回溯呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP