题目链接:http://codeforces.com/problemset/problem/468/A

题目意思:给出一个数n,利用 1 ~ n 这 n 个数,每个数只能用一次,能否通过3种运算: +、-、* 使得最后的结果为24。

首先大方向想得是对的,就是用前面尽量连续的数构成24,而后面就通过相互抵消变成0,这样就不会影响到前面算出的结果。

但有两个地方比较致命,所以最终要看着test的数据改~~。首先没有留意到 n 个数操作的次数恰好为 n - 1 次!!(之前千辛万苦找到构成24的方法由于遗漏这个条件,几乎付诸东流啊~~)。其次,抵消方式不正确。我的抵消方式是通过 +1, -1,..., 相加来变成0的。这样意味着,除去前面那些能构成24的数(假设以k结尾),次数为k-1次,后面n-k个数,即 k+1, k+2,...,n,要 操作 n - k 次,但我这样的抵消方式操作的次数是得不出n-k的,而且还有个比较苛刻的条件,后面这n-k个数构成的对数一定要为偶数对(每对为两个),这样通过两两配对,次数就是(n-k)/4 * 3 (4表示每组看成连续的两对数,3表示每组数操作3次:  1,-1, 1-1 = 0)。

自从看了test3 的数据之后,一下子茅塞顿开啊~~~~

很容易知道,n < 4 是无解的 !!!

而1 2 3 4(操作3次,1*2,2*3,6*4) 是可以得出24的,1 2 3 4 5(看代码吧,只是其中一种构造方法) 也能构成24的!!那么剩下的数怎么办?剩下的数保证要操作n-k次。通过后一个减前一个数,得出1,再不断乘以 24,这样就大功告成啦^_^。而且这样做的好处是,不用为后面的有多少对 对数烦恼。试想,一个n个数的序列无非只有两种:最后一个数以奇数结尾或者以偶数结尾。奇数结尾自然调用 1 2 3 4 5 来构成24这个方法;而偶数结尾就用1 2 3 4 能构成24,这样就能保证 n - 4 或者 n - 5 之后的数能成对构成1,再与24相乘即可。

构造题就是那么考思维呀,但一般不难~~~~想了我大半天= =

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstdlib>
  4. #include <cstring>
  5. using namespace std;
  6.  
  7. int cnt;
  8. inline void remain(int st, int end)
  9. {
  10. cnt = ; // 对数
  11. for (int i = st+; i <= end; i += )
  12. {
  13. cnt++;
  14. printf("%d - %d = 1\n", i, i-);
  15. }
  16. }
  17.  
  18. inline void Output(int cnt)
  19. {
  20. for (int i = ; i < cnt; i++)
  21. printf("24 * 1 = 24\n");
  22. }
  23.  
  24. int main()
  25. {
  26. int n;
  27. #ifndef ONLINE_JUDGE
  28. freopen("in.txt", "r", stdin);
  29. #endif // ONLINE_JUDGE
  30.  
  31. while (scanf("%d", &n) != EOF)
  32. {
  33. if (n < )
  34. printf("NO\n");
  35. else
  36. {
  37. printf("YES\n");
  38. if ((n-) % == )
  39. {
  40. printf("1 * 2 = 2\n");
  41. printf("2 * 3 = 6\n");
  42. printf("6 * 4 = 24\n");
  43. remain(, n);
  44. }
  45. else
  46. {
  47. printf("3 * 5 = 15\n");
  48. printf("2 * 4 = 8\n");
  49. printf("15 + 8 = 23\n");
  50. printf("23 + 1 = 24\n");
  51. remain(, n);
  52. }
  53. Output(cnt);
  54. }
  55.  
  56. }
  57. return ;
  58. }

codeforces 468A. 24 Game 解题报告的更多相关文章

  1. Codeforces Round 665 赛后解题报告(暂A-D)

    Codeforces Round 665 赛后解题报告 A. Distance and Axis 我们设 \(B\) 点 坐标为 \(x(x\leq n)\).由题意我们知道 \[\mid(n-x)- ...

  2. Codeforces Round 662 赛后解题报告(A-E2)

    Codeforces Round 662 赛后解题报告 梦幻开局到1400+的悲惨故事 A. Rainbow Dash, Fluttershy and Chess Coloring 这个题很简单,我们 ...

  3. Codeforces Round #277.5 解题报告

    又熬夜刷了cf,今天比正常多一题.比赛还没完但我知道F过不了了,一个半小时贡献给F还是没过--应该也没人Hack.写写解题报告吧= =. 解题报告例如以下: A题:选择排序直接搞,由于不要求最优交换次 ...

  4. codeforces B. Simple Molecules 解题报告

    题目链接:http://codeforces.com/problemset/problem/344/B 题目意思:这句话是解题的关键: The number of bonds of an atom i ...

  5. codeforces A. Candy Bags 解题报告

    题目链接:http://codeforces.com/contest/334/problem/A 题意:有n个人,将1-n袋(第 i  袋共有 i  颗糖果,1<= i  <=n)所有的糖 ...

  6. codeforces 591A. Wizards' Duel 解题报告

    题目链接:http://codeforces.com/problemset/problem/591/A 题目意思:其实看下面这幅图就知道题意了,就是Harry 和 He-Who-Must-Not-Be ...

  7. codeforces 582A. GCD Table 解题报告

    题目链接:http://codeforces.com/problemset/problem/582/A 网上很多题解,就不说了,直接贴代码= = 官方题解: http://codeforces.com ...

  8. codeforces 581C. Developing Skills 解题报告

    题目链接:http://codeforces.com/problemset/problem/581/C 题目意思:给出 n 个数:a1, a2, ..., an (0 ≤ ai ≤ 100).给出值 ...

  9. codeforces 577B. Modulo Sum 解题报告

    题目链接:http://codeforces.com/problemset/problem/577/B 题目意思:就是给出 n 个数(a1, a2, ..., an) 和 m,问能不能从这 n 个数中 ...

随机推荐

  1. Spring+C3P0数据库连接池配置

    一.xml文件读取.properties文件连接数据库 1.xml文件中的配置 <bean id="dataSourceLocal" name="dataSourc ...

  2. springMVC实现防止重复提交

    参考文档:http://my.oschina.net/mushui/blog/143397

  3. sqlserver字段类型详解

    抄了一篇不错的数据库类型,来自:http://www.cnblogs.com/andy_tigger/archive/2011/08/21/2147745.html bit 整型 bit数据类型是整型 ...

  4. jquery ajax提交表单数据的两种方式

    http://www.kwstu.com/ArticleView/kwstu_201331316441313 貌似AJAX越来越火了,作为一个WEB程序开发者要是不会这个感觉就要落伍,甚至有可能在求职 ...

  5. resharper安装后,一不小心点错了(选择了object browser)

    打开Resharper,选择Options,然后选择Tools中的External Sources,你的情况是选择了Navigation to Object Brower这一项了,换成第一个Defau ...

  6. go tool proof

    echo list | go tool pprof -alloc_space gateway http://10.2.1.93:8421/debug/pprof/heap > abc.log e ...

  7. iptables相关

    ⑴.Iptables规则写法的基本格式是:    Iptables [-ttable] COMMAND chain CRETIRIA -j ACTION   ⑵.Iptables规则相关参数说明:  ...

  8. 三大框架ssh

    一.hibernate a.实体类+映射 b.lib  hibernate包+oracle包(oracle安装里找) 映射:从类入手class+属性 a.映射的头文件在:hibernate3.jar- ...

  9. 如何在eclipse中使用XYLayout布局?在此介绍如何把XYLayout导入到eclipse .

    XYLayout布局是jbuilder中自带的布局,它存在于jbcl.jar包中 ,而jbcl.jar包在JBuilder安装目录的lib目录下.它是每个控件按(x,y)坐标安排位置的布局.属于Bor ...

  10. JQuery元素获取

    前言:这是本类别博文JQuery即用即查开篇. 因为查手册太麻烦,而且有时候需要深入命令所在详细页面才能了解此命令的具体作用是什么. 写这几篇文章就是为了,工作遇到问题时,一看这几篇文章就可以查到哪个 ...