【题目大意】

有许多木块, 叠放时, 必须正着叠放, 如图1, 左边两块为合法叠放, 右边为不合法叠放.

图1

一个方块被称为稳定的, 当且仅当其放在最底层, 或其正下方有方块且下方的这个方块的四周都有方块. 叠放必须保证所有方块都稳定. 如图2, 左边3个叠放为合法叠放, 右边2个叠放为不合法叠放.

给定一个n,求能叠出的最高稳定建筑的高度

n<=

【解题】考虑每一种高度,至少需要多少个方块,我们计算出这些值,随便维护一下就好了呀qwq

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<algorithm>
  4. using namespace std;
  5. #define FO(x) freopen(#x".in","r",stdin),freopen(#x".out","w",stdout)
  6. long long f,sum;
  7. int n;
  8. int main(){
  9. FO(block);
  10. scanf("%d",&n);
  11. f=sum=;
  12. if(sum>=n){
  13. puts("");return ;
  14. }
  15. for(int i=;;i++){
  16. f=f+(i-)*;
  17. sum=sum+f;
  18. if(sum>=n){
  19. cout<<i-(sum!=n);
  20. return ;
  21. }
  22. }
  23. }

T2 hanoi

【题目大意】

汉诺塔游戏众所皆知, 现在制定一个如下新的汉诺塔游戏规则:

共ABC三柱, 起初所有的盘子按从上到下从小到大的顺序排列在A柱, 移动规则依然是只能移动最顶端的盘子, 且一个盘子只能放在更大的盘子上方. 现增加一个规则, 同一个盘子不能被连续移动两次. 现有序列{AB, AC, BA, BC, CA, CB}(AB即表示将A的最上方的盘子移到B)的任一排序, 每次移动必须是在该序列中找到最早的一个合法的操作, 并移动. .(全部移动到BC任意一个柱子上即视为游戏结束.)

第一行输入一个整数n(n<=20),第二行输入一个操作序列,形同AB, AC, BA, BC, CA, CB

求游戏结束时所用操作数

【解题】

由于第二行的输入只有 6!种 ,可以大胆猜测所有n对于这6!种操作序列的答案是有规律的,发现n=3的时候答案只有三种,那么我们对于操作序列暴力跑一下n=3的情况,判断这个操作序列的答案属于哪一种,直接计算即可

  1. #include<queue>
  2. #include<cstdio>
  3. #include<iostream>
  4. #include<algorithm>
  5. using namespace std;
  6. #define FO(x) freopen(#x".in","r",stdin),freopen(#x".out","w",stdout)
  7. char mov[][];
  8. typedef long long ll;
  9. ll cnt;bool ok;int n;
  10. int top[],qu[][];
  11. void dfs(int lst,int dep){
  12. if(dep>=cnt)return;
  13. if(!top[]&&(!top[]||!top[])){
  14. ok=;
  15. return;
  16. }
  17. for(int i=;i<;i++){
  18. int a=mov[i][]-'A',b=mov[i][]-'A';
  19. if(!top[a]||a==lst)
  20. continue;
  21. int t=qu[a][top[a]];
  22. if(top[b]&&t>qu[b][top[b]]) continue;
  23. --top[a];
  24. qu[b][++top[b]]=t;
  25. dfs(b,dep+);
  26. --top[b];
  27. if(ok) return;
  28. qu[a][++top[a]]=t;
  29. break;
  30. }
  31. }
  32. int luangao(){
  33. ok=;
  34. top[]=top[]=top[]=cnt=;
  35. for(int i=;i>=;i--) qu[][++top[]]=i;
  36. do{
  37. dfs(-,);
  38. ++cnt;
  39. if(cnt>) break;
  40. }while(!ok);
  41. int P=cnt-;
  42. return P;
  43. }
  44. void c233(){
  45. ll x=;
  46. for(int i=;i<=n;i++) x=x*;
  47. cout<<x-;
  48. }
  49. void pow2(){
  50. ll x=;
  51. for(int i=;i<=n;i++) x=x*;
  52. cout<<x-;
  53. }
  54. void pow3(){
  55. ll x=;
  56. for(int i=;i<=n;i++) x=x*;
  57. cout<<x;
  58. }
  59. int main(){
  60. FO(hanoi);
  61. //6*???*2^???
  62. scanf("%d",&n);
  63. for(int i=;i<;i++)scanf("%s",mov[i]);
  64. int ans3=luangao();
  65. if(ans3==)c233();
  66. else if(ans3==)pow2();
  67. else if(ans3==)pow3();
  68. else cout<<"规律不对啊 日";
  69.  
  70. }

20160722noip模拟赛alexandrali的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. NOI模拟赛 Day1

    [考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...

  3. NOIP第7场模拟赛题解

    NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...

  4. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  5. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  6. 小奇模拟赛9.13 by hzwer

    2015年9月13日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...

  7. PKUSC 模拟赛 day1 下午总结

    下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...

  8. [GRYZ]寒假模拟赛

    写在前面 这是首次广饶一中的OIERS自编自导,自出自做(zuo)的模拟赛. 鉴于水平气压比较低,机(wei)智(suo)的WMY/XYD/HYXZC就上网FQ下海找了不少水(fei)题,经过他们优( ...

  9. BZOJ2741: 【FOTILE模拟赛】L

    2741: [FOTILE模拟赛]L Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 1170  Solved: 303[Submit][Status] ...

随机推荐

  1. swift创建对象use of undeclared type 自己的类

    在swift项目中,引用自己创建的类,编译会成功的,但是会出现红色感叹号,类似报错,如:swift创建对象use of  undeclared type 自己的类,或者 use of unresolv ...

  2. Xcode中常用的快捷键

    各种新建 shift + comand + n 新建xcode项目   option + command + n 新建分组  command + n 新建文件 搜索 shift + command + ...

  3. WCF之消息模式

    请求/响应:所有操作的默认行为,在WSDL中表现为Input/Output元素. One_Way. 在WSDL中只有Input,没有回应(Output),所以没有异常报告. 单向操作只会在发出调用的瞬 ...

  4. highcharts实现统计图效果

    highcharts实现统计图效果 ① 根据需求确定需要使用的案例图 把这个界面的html模板文件复制出来,放入./Application/Admin/View/User下改名为chart.html ...

  5. .NET中的标识符、关键字 以及 .NET中的命名规范

    1.关键字 C#定义了一些关键字(public/static/void/class/int/string),这些关键字是构成C#基本语法用的. VS中蓝色字的才是关键字. Main.String.Co ...

  6. 6.ipv6地址配置

    1. "nmcli connection modify 网卡名 ipv4.addresses "ipv6地址" ipv6.method manual ". 2. ...

  7. 使用FormData上传文件、图片

    关于FormData XMLHttpRequest Level 2添加了一个新的接口  ---- FormData 利用FormData对象,可以通过js用一些键值对来模拟一系列表单控件,可以使用XM ...

  8. jexus 配置 学习

    http://www.linuxdot.net/ 1.禁止或允许某IP或IP段访问网站 A.只允许某些IP地址访问网站(白名单功能) 默认情况下,允许所有IP地址访问.如果手工设置IP地址白名单, 那 ...

  9. Android 多国语言

    参考android 开发文档,  ISO 639-1  ISO 3166-1-alpha-2 关于中国的: 中国其他地区: https://en.wikipedia.org/wiki/ISO_3166 ...

  10. PHP实现根据浏览器跳转不同语言页面代码

    以下是对使用PHP实现根据浏览器跳转不同语言页面的代码进行了介绍,需要的朋友可以过来参考下 代码: <?php /** * 根据不同浏览器跳转不同页面 * 来源:www.jbxue.com * ...