codeforces 468A. 24 Game 解题报告
题目链接: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相乘即可。
构造题就是那么考思维呀,但一般不难~~~~想了我大半天= =
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std; int cnt;
inline void remain(int st, int end)
{
cnt = ; // 对数
for (int i = st+; i <= end; i += )
{
cnt++;
printf("%d - %d = 1\n", i, i-);
}
} inline void Output(int cnt)
{
for (int i = ; i < cnt; i++)
printf("24 * 1 = 24\n");
} int main()
{
int n;
#ifndef ONLINE_JUDGE
freopen("in.txt", "r", stdin);
#endif // ONLINE_JUDGE while (scanf("%d", &n) != EOF)
{
if (n < )
printf("NO\n");
else
{
printf("YES\n");
if ((n-) % == )
{
printf("1 * 2 = 2\n");
printf("2 * 3 = 6\n");
printf("6 * 4 = 24\n");
remain(, n);
}
else
{
printf("3 * 5 = 15\n");
printf("2 * 4 = 8\n");
printf("15 + 8 = 23\n");
printf("23 + 1 = 24\n");
remain(, n);
}
Output(cnt);
} }
return ;
}
codeforces 468A. 24 Game 解题报告的更多相关文章
- Codeforces Round 665 赛后解题报告(暂A-D)
Codeforces Round 665 赛后解题报告 A. Distance and Axis 我们设 \(B\) 点 坐标为 \(x(x\leq n)\).由题意我们知道 \[\mid(n-x)- ...
- Codeforces Round 662 赛后解题报告(A-E2)
Codeforces Round 662 赛后解题报告 梦幻开局到1400+的悲惨故事 A. Rainbow Dash, Fluttershy and Chess Coloring 这个题很简单,我们 ...
- Codeforces Round #277.5 解题报告
又熬夜刷了cf,今天比正常多一题.比赛还没完但我知道F过不了了,一个半小时贡献给F还是没过--应该也没人Hack.写写解题报告吧= =. 解题报告例如以下: A题:选择排序直接搞,由于不要求最优交换次 ...
- codeforces B. Simple Molecules 解题报告
题目链接:http://codeforces.com/problemset/problem/344/B 题目意思:这句话是解题的关键: The number of bonds of an atom i ...
- codeforces A. Candy Bags 解题报告
题目链接:http://codeforces.com/contest/334/problem/A 题意:有n个人,将1-n袋(第 i 袋共有 i 颗糖果,1<= i <=n)所有的糖 ...
- codeforces 591A. Wizards' Duel 解题报告
题目链接:http://codeforces.com/problemset/problem/591/A 题目意思:其实看下面这幅图就知道题意了,就是Harry 和 He-Who-Must-Not-Be ...
- codeforces 582A. GCD Table 解题报告
题目链接:http://codeforces.com/problemset/problem/582/A 网上很多题解,就不说了,直接贴代码= = 官方题解: http://codeforces.com ...
- codeforces 581C. Developing Skills 解题报告
题目链接:http://codeforces.com/problemset/problem/581/C 题目意思:给出 n 个数:a1, a2, ..., an (0 ≤ ai ≤ 100).给出值 ...
- codeforces 577B. Modulo Sum 解题报告
题目链接:http://codeforces.com/problemset/problem/577/B 题目意思:就是给出 n 个数(a1, a2, ..., an) 和 m,问能不能从这 n 个数中 ...
随机推荐
- webservice配置
服务端配置:第一步:引用jar包commons-httpclient.jarcommons-logging.jarjdom-10.jarwsdl4j-1.6.1.jarxbean-spring-2.8 ...
- BZOJ-1968 COMMON 约数研究 数论+奇怪的姿势
1968: [Ahoi2005]COMMON 约数研究 Time Limit: 1 Sec Memory Limit: 64 MB Submit: 1513 Solved: 1154 [Submit] ...
- 【poj3714】 Raid
http://poj.org/problem?id=3714 (题目链接) 现在才搞平面最近点对..感觉有点尴尬 题意 给出平面上两组点,每组n个,求两组点之间最短距离 Solution1 平面最近点 ...
- TYVJP1933 绿豆蛙的归宿
背景 随着新版百度空间的上线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿. 描述 给出一个有向无环图,起点为1终点为N,每条边都有一个长度,并且从起点出发能够到达所有的点,所有的点也都能够到达 ...
- PL/0编译器(java version) - Err.java
1: package compiler; 2: 3: import java.io.BufferedWriter; 4: 5: public class Err { 6: 7: publi ...
- 车牌号对应归属地及城市JSON带简码
车牌号对应归属地及城市JSON带简码 car_city.json [ { "code": "冀A", "city": "石家庄&q ...
- android button 函数调用栈
Button button=(Button) findViewById(R.id.button);button.setOnClickListener(new Button.OnClickListene ...
- javaweb学习总结(三十一)——国际化(i18n)
一.国际化开发概述 软件的国际化:软件开发时,要使它能同时应对世界不同地区和国家的访问,并针对不同地区和国家的访问,提供相应的.符合来访者阅读习惯的页面或数据. 国际化(internationaliz ...
- MyEclipse中防止代码格式化时出现换行的情况的设置
编辑完成代码,用MyEclipse的代码格式化后,本来不长的代码也被自动转成了多行.虽然自动换行以后在编辑器中一眼就能看到全部的代码,但是可读性却大打折扣,避免出现这种情况的办法是: 1.Java代码 ...
- javascript滚动条之ScrollBar.js
ScrollBar.js是一个仅仅120行的滚动条JS插件,使用非常方便 详情阅读:https://git.oschina.net/wuquanyao/scrollbar.js/*========== ...