【u107】数字游戏(bds)
Time Limit: 1 second
Memory Limit: 128 MB
【问题描述】
有这么一个游戏: 写出一个1~N的排列a[i],然后每次将相邻两个数相加,构成新的序列,再对新序列进行这样的操作,显然每次构成的序列都比上一次的序列长度少1,直到只剩下一个数字位置。下面是一个例子:
3 1 2 4
4 3 6
7 9
16
最后得到16这样一个数字。 现在想要倒着玩这样一个游戏,如果知道N,知道最后得到的数字的大小sum,请你求出最初序列a[i],为1~N的一个排列。若答案有多种可能,则输出字典序最小的那一个。
【输入格式】
输入文件bds.in的第1行为两个正整数n,sum。
【输出格式】
输出文件bds.out包括1行,为字典序最小的那个答案。
【数据规模】
对于40%的数据,n≤7; 对于80%的数据,n≤10; 对于100%的数据,n≤12,sum≤12345,且保证一定有解。
Sample Input1
4 16
Sample Output1
3 1 2 4
【题解】
从最下面往上推
a上面的b和c都会被加1次。
再往上则d会因为d+e=b 加1次。
e会因为d+e和e+f加2次。
f会因为e+f加一次。
所以d用了1次,e用了2次,f用了1次。
再往上。
g会因为g+h=d加一次
h会因为g+h加一次,还会因为h+i==e加两次。因为e被加了两次。
同理i因为h+i==e加了两次因为i+j==f加了一次。
j因为i+j==f加了一次。
综上g,h,i,j分别加了1,3,3,1次。
可以看出来是杨辉三角了。
知道了每个序列中的每一个元素最后会加几次。就不用一层一层地算下来了。
以后只要枚举完一个序列。直接用那些1,3,3,1这样的数字作为系数。乘上序列中的相应位置上的数字就可以了。
注意是1-n的全排列。
【代码】
#include <cstdio>
#include <cstring>
#include <stdlib.h> int n,sum;
int yanghui[20][20]= {0},what[20];
bool bo[20]; void input_data()
{
memset(bo,0,sizeof(bo)); //每个数字一开始都没有被用过。
scanf("%d%d",&n,&sum);
yanghui[1][1] = 1;
for (int i = 2;i <= n;i++) //处理出第n层的杨辉三角
for (int j = 1;j <= i;j++)
yanghui[i][j] = yanghui[i-1][j-1]+yanghui[i-1][j];
} void sear_ch(int next,int now) //要找的下一个是next,当前累加的值为now
{
if (now > sum) //如果大于sum了则剪枝
return;
if (next == n+1) //如果找完n个数字则判断是否和sum相同。
{
if (now == sum)
{
for (int i = 1;i <=n-1;i++) //输出答案。
printf("%d ",what[i]);
printf("%d",what[n]);
exit(0);
}
return;
}
for (int i = 1;i <= n;i++) //继续枚举数字放在next的位置
if (!bo[i]) //没有用过
{
bo[i] = true; //记录用过
what[next] = i; //记录用了什么数字
sear_ch(next+1,now+yanghui[n][next]*i); //乘上相应的系数即可。
bo[i] = false;
}
} void get_ans()
{
for (int i = 1;i <= n;i++) i//这是第一个数字。
if (!bo[i])
{
bo[i] = true; //记录i这个数字已经被使用过了。
what[1] = i; //记录这个位置放什么
sear_ch(2,yanghui[n][1]*i);//进入递归。
bo[i] = false;
}
} int main()
{
input_data();
get_ans();
return 0;
}
【u107】数字游戏(bds)的更多相关文章
- C语言猜数字游戏
猜数字游戏,各式各样的实现方式,我这边提供一个实现方式,希望可以帮到新手. 老程序猿就不要看了,黑呵呵 源代码1 include stdio.h include stdlib.h include ti ...
- 不一样的猜数字游戏 — leetcode 375. Guess Number Higher or Lower II
好久没切 leetcode 的题了,静下心来切了道,这道题比较有意思,和大家分享下. 我把它叫做 "不一样的猜数字游戏",我们先来看看传统的猜数字游戏,Guess Number H ...
- java 猜数字游戏
作用:猜数字游戏.随机产生1个数字(1~10),大了.小了或者成功后给出提示. 语言:java 工具:eclipse 作者:潇洒鸿图 时间:2016.11.10 >>>>> ...
- 【原创Android游戏】--猜数字游戏Version 0.1
想当年高中时经常和小伙伴在纸上或者黑板上或者学习机上玩猜数字的游戏,在当年那个手机等娱乐设备在我们那还不是很普遍的时候是很好的一个消遣的游戏,去年的时候便写了一个Android版的猜数字游戏,只是当时 ...
- 【原创Android游戏】--猜数字游戏V1.1 --数据存储,Intent,SimpleAdapter的学习与应用
--------------------------------------------------------------- V0.1版本 上次做完第一个版本后,发现还有一些漏洞,并且还有一些可以添 ...
- NOIP2003pj数字游戏[环形DP]
题目描述 丁丁最近沉迷于一个数字游戏之中.这个游戏看似简单,但丁丁在研究了许多天之后却发觉原来在简单的规则下想要赢得这个游戏并不那么容易.游戏是这样的,在你面前有一圈整数(一共n个),你要按顺序将其分 ...
- Codevs 1229 数字游戏
1229 数字游戏 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题目描述 Description Lele 最近上课的时候都很无聊,所以他发明了 ...
- codevs 1229 数字游戏(可重集的全排列)
传送门 Description Lele 最近上课的时候都很无聊,所以他发明了一个数字游戏来打发时间. 这个游戏是这样的,首先,他拿出几张纸片,分别写上0到9之间的任意数字(可重复写某个数字),然后 ...
- XDU 1161 - 科协的数字游戏II
Problem 1161 - 科协的数字游戏II Time Limit: 1000MS Memory Limit: 65536KB Difficulty: Total Submit: 112 ...
随机推荐
- CMake学习笔记四-CMake常用命令
CMake常用命令 PROJECT PROJECT(projectname [CXX] [C] [Java]) 指定工程名称,并可指定工程支持的语言.支持语言列表可忽略,默认支持所有语言 SET ...
- 解决Apache日志"internal dummy connection"方法
最近查看服务器中apache日志,发现有大量的 OPTIONS * HTTP/1.0" 200 - "-" "Apache (internal dummy co ...
- cp和mv命令
注意事项:mv与cp的结果不同,mv好像文件“搬家”,文件个数并未增加.而cp对文件进行复制,文件个数增加了. 一.cp命令 cp命令用来将一个或多个源文件或者目录复制到指定的目的文件或目录.它可以将 ...
- 【JZOJ4928】【NOIP2017提高组模拟12.18】A
题目描述 数据范围 对于100%的数据,n<=100000,1<=A[i]<=5000 =w= Ans=∏1ai 代码 #include<iostream> #inclu ...
- day39-Spring 05-Spring的AOP:不带有切点的切面
Spring底层的代理的实现: 不带切点的切面是对类里面的所有的方法都进行拦截. 做Spring AOP的开发需要两个包:一个是AOP的包,一个是AOP联盟的包(因为规范是由AOP联盟提出来的). 用 ...
- 使用cmd发送邮件
转自:http://www.cnblogs.com/fanyong/p/3498670.html 本文演示用命令行发送邮件的过程. SMTP 首先介绍下smtp协议——简单邮件传输协议 (Simple ...
- shell学习(22)- comm
1.预备知识 comm命令可用于比较两个已排序的文件.它可以显示出第一个文件和第二个文件所独有的行以及这两个文件所共有的行.该命令有一些选项可以禁止显示指定的列,以便于执行交集和求差操作. 交集(in ...
- 惊闻!SOIC 和 SOP 竟然是有区别的
目录 惊闻!SOIC 和 SOP 竟然是有区别的 原因 对比 结论 惊闻!SOIC 和 SOP 竟然是有区别的 原因 一直以为 SOIC 和 SOP 是一样的,只是叫法不同. 对比 今天仔细查了才发现 ...
- 2018-10-19-Roslyn-使用-Directory.Build.props-文件定义编译
title author date CreateTime categories Roslyn 使用 Directory.Build.props 文件定义编译 lindexi 2018-10-19 18 ...
- BZOJ 3884 上帝与集合的正确用法题解
一道智慧题 其实解这题需要用到扩展欧拉定理, 有了上面的公式,我们不难看出此题的解法. 设b为2^2^2^2^2.....显然,b要比φ(p)要大,所以可以直接套公式 modp时的答案 ans(p)= ...