Time Limit: 3 second

Memory Limit: 256 MB

【问题描述】

有这么一个游戏: 写出一个1~N的排列a[i],然后每次将相邻两个数相加,构成新的序列,再对新序列进行这样的操作,显然每次构成的序列都比上一次的序列长度少1,直到只剩下一个数字位置。下面是一个例子:

3 1 2 4

4 3 6

7 9

16

最后得到16这样一个数字。

现在想要倒着玩这样一个游戏,如果知道N,知道最后得到的数字的大小sum,请你求出最初序列a[i],为1~N的一个排列。若答案有多种可能,则输出字典序最小的那一个。

【数据规模】

对于40%的数据,n≤7;

对于80%的数据,n≤10;

对于100%的数据,n≤12,sum≤12345,且保证一定有解。

【输入格式】

  1. 输入文件bds.in的第1行为两个正整数nsum

【输出格式】

  1. 输出文件bds.out包括1行,对于每个询问输出答案。

【输入样例1】

4 16

【输出样例1】

3 1 2 4

【题目链接】:http://noi.qz5z.com/viewtask.asp?id=t030

【题解】



可以画一画样例



注意观察一下最后的答案;

发现其实最后答案=3*1+3*2+1*3+1*4

可以看到第一行的各项的系数是分别是C[3][0],C[3][1],C[3][2],C[3][3];

发现规律!

最后的答案就为

设第一行的第i列元素为a[i]

则最后一行的那一个元素为∑a[i]*C[n-1][i-1]

则我们先预处理出组合数(C[i][j] = C[i-1][j-1]+C[i-1][j])

然后枚举第一行的各个元素分别是什么;

然后O(1)得到最后一行的那唯一一个元素;

看看是不是所要求的sum;

因为这个∑符号里面的各项都是正数,所以可以写一个剪枝;

如果前i项的∑a[i]*C[n-1][i]>sum,则直接剪掉;就不用再等到i=n的时候再判断了;

sum比较小;这个剪枝还是很强力的;



【完整代码】

  1. #include <cstdio>
  2. #include <cstdlib>
  3. #define rei(x) scanf("%d",&x)
  4. #define rep1(i,x,y) for (int i = x;i <= y;i++)
  5. const int MAXN = 15;
  6. int n,sum,a[MAXN];
  7. int c[MAXN][MAXN];
  8. bool bo[MAXN];
  9. void dfs(int x,int now)
  10. {
  11. if (now > sum)
  12. return;
  13. if (x>n)
  14. {
  15. if (now==sum)
  16. {
  17. rep1(i,1,n)
  18. {
  19. printf("%d",a[i]);
  20. if (i==n)
  21. puts("");
  22. else
  23. putchar(' ');
  24. }
  25. exit(0);
  26. }
  27. return;
  28. }
  29. rep1(i,1,n)
  30. if (!bo[i])
  31. {
  32. bo[i] = true;
  33. a[x] = i;
  34. dfs(x+1,now+c[n-1][x-1]*a[x]);
  35. bo[i] = false;
  36. }
  37. }
  38. int main()
  39. {
  40. rep1(i,1,13)
  41. c[i][i] = c[i][0] = 1;
  42. rep1(i,1,13)
  43. rep1(j,1,i-1)
  44. c[i][j] = c[i-1][j-1]+c[i-1][j];
  45. rei(n);rei(sum);
  46. if (n==1)
  47. puts("1");
  48. else
  49. dfs(1,0);
  50. return 0;
  51. }

【t030】数字构造的更多相关文章

  1. 【t005】数字构造问题

    Time Limit: 1 second Memory Limit: 50 MB [问题描述] 给定一个只包含数字[0..9]的字符串,请使用字符串中的某些字符,构建一个能够整除15最大的整数.注意, ...

  2. 浅谈无字母数字构造webshell

    0x00 问题 <?php include 'flag.php'; if(isset($_GET['code'])){ $code = $_GET['code']; if(strlen($cod ...

  3. TTTTTTTTTTTTTT CF 95 B 构造4,7幸运数字 贪心 构造 string

    B. Lucky Numbers time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

  4. 涨姿势:抛弃字母、数字和下划线写SHELL

    PHP中异或 (^) 的概念 <?php echo"A"^"?";?> <?php echo"A"^"?&quo ...

  5. java面试题总汇

    coreJava部分 7 1.面向对象的特征有哪些方面? 7 2.作用域public,private,protected,以及不写时的区别? 7 3.String 是最基本的数据类型吗? 7 4.fl ...

  6. BZOJ 4724: [POI2017]Podzielno

    Description 由\([0,B-1]\)的数字构造一个 \(B\) 进制数字,使得他是 \(B-1\) 的倍数. Sol 贪心+二分. 首先 \(X\) 是 \(B-1\) 的倍数,那么有 \ ...

  7. boost学习笔记(七)---date_time库

    date_time库的日期基于格里高利历,支持从1400-01-01到9999-12-31之间的日期计算 #define BOOST_DATE_TIME_SOURCE #include <boo ...

  8. Winform开发框架之统计图表的实现

    在前面的一些随笔中,介绍了不少我的Winform框架的特性,上篇随笔<Winform开发框架之通用高级查询模块>对其中的通用高级模块进了一个整理说明,本篇继续介绍Winform开发框架重要 ...

  9. [转载]Winform开发框架之统计图表的实现

    在前面的一些随笔中,介绍了不少我的Winform框架的特性,上篇随笔<Winform开发框架之通用高级查询模块>对其中的通用高级模块进了一个整理说明,本篇继续介绍Winform开发框架重要 ...

随机推荐

  1. ListCtrl添加右键菜单(在对话框类中)

    在对话框类中如何添加NM_RCLICK消息: ListCtrl控件右键单击选择属性 在右侧属性栏中选择控件事件 在控件事件中找到NM_RCLICK并添加 完成,写代码

  2. 【iOS开发-29】解决方式:TabBar的图片不显示,仅仅显示灰色的正方形

    (1)现象 tabbar上的图片变成一块正方形的灰色块块,原先的图片没有了. (2)原因 tabbar上的图片本质上不是一个图片.而是一个形状图片.系统对我们使用的图片也仅仅是把当中的形状" ...

  3. jquery ui 分页插件 传入后台的连个參数名

    參数名: page .rows page=int(request.form.get('page',1).encode('u8')) rows1=int(request.form.get('rows', ...

  4. Android学习笔记之按键操作

    我们如何和Android 程序来进行交互那份?来让 Android 程序产生相应的反应,我们不得不通过键盘事件.触摸事件.传感器事件等来实现. 键盘是Android中主要的输入设备,对按键的响应的处理 ...

  5. 119.WIN32窗口原理

    #include <Windows.h> //处理消息的回调函数 LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM); int WIN ...

  6. vue权限控制菜单显示的简单实现

    为了对于不同角色显示不同的菜单 思路1: 本地放一份完整的菜单数据,通过后台返回角色的菜单列表.两者对比,筛选需要显示的菜单数据绑定, 这里有个问题就是路由vue实例初始化就生成了,加载的全部,人为输 ...

  7. MySQL系列之七:主从复制(转)

    一:实验环境 IP 操作系统 mysql版本号 master 192.168.25.11 CentOS7 5.6.35 slave 192.168.25.10 win10 5.7.18 slave版本 ...

  8. oracle 多行转多列查询

     oracle 多行转多列查询  ---create table Fruit(id int,name varchar(20), Q1 int, Q2 int, Q3 int, Q4 int);inse ...

  9. Altium Designer如何创建类,如何修改线宽

    如果线宽还是没有改变,就是因为,有一个默认的class,它的规则优先级要高于PWR

  10. (转)chrome浏览器收藏夹(书签)的导出与导入

    导出chrome浏览器的书签到一个文件中.首先选择chrome浏览器的书签管理器菜单.然后点击“整理”,然后选择“将书签导出到html文件”. 步骤阅读 2 将导出的html文件保存,用于下次导入,这 ...