20160722noip模拟赛alexandrali
【题目大意】
有许多木块, 叠放时, 必须正着叠放, 如图1, 左边两块为合法叠放, 右边为不合法叠放.
图1
一个方块被称为稳定的, 当且仅当其放在最底层, 或其正下方有方块且下方的这个方块的四周都有方块. 叠放必须保证所有方块都稳定. 如图2, 左边3个叠放为合法叠放, 右边2个叠放为不合法叠放.
给定一个n,求能叠出的最高稳定建筑的高度
n<=
【解题】考虑每一种高度,至少需要多少个方块,我们计算出这些值,随便维护一下就好了呀qwq
- #include<cstdio>
- #include<iostream>
- #include<algorithm>
- using namespace std;
- #define FO(x) freopen(#x".in","r",stdin),freopen(#x".out","w",stdout)
- long long f,sum;
- int n;
- int main(){
- FO(block);
- scanf("%d",&n);
- f=sum=;
- if(sum>=n){
- puts("");return ;
- }
- for(int i=;;i++){
- f=f+(i-)*;
- sum=sum+f;
- if(sum>=n){
- cout<<i-(sum!=n);
- return ;
- }
- }
- }
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的情况,判断这个操作序列的答案属于哪一种,直接计算即可
- #include<queue>
- #include<cstdio>
- #include<iostream>
- #include<algorithm>
- using namespace std;
- #define FO(x) freopen(#x".in","r",stdin),freopen(#x".out","w",stdout)
- char mov[][];
- typedef long long ll;
- ll cnt;bool ok;int n;
- int top[],qu[][];
- void dfs(int lst,int dep){
- if(dep>=cnt)return;
- if(!top[]&&(!top[]||!top[])){
- ok=;
- return;
- }
- for(int i=;i<;i++){
- int a=mov[i][]-'A',b=mov[i][]-'A';
- if(!top[a]||a==lst)
- continue;
- int t=qu[a][top[a]];
- if(top[b]&&t>qu[b][top[b]]) continue;
- --top[a];
- qu[b][++top[b]]=t;
- dfs(b,dep+);
- --top[b];
- if(ok) return;
- qu[a][++top[a]]=t;
- break;
- }
- }
- int luangao(){
- ok=;
- top[]=top[]=top[]=cnt=;
- for(int i=;i>=;i--) qu[][++top[]]=i;
- do{
- dfs(-,);
- ++cnt;
- if(cnt>) break;
- }while(!ok);
- int P=cnt-;
- return P;
- }
- void c233(){
- ll x=;
- for(int i=;i<=n;i++) x=x*;
- cout<<x-;
- }
- void pow2(){
- ll x=;
- for(int i=;i<=n;i++) x=x*;
- cout<<x-;
- }
- void pow3(){
- ll x=;
- for(int i=;i<=n;i++) x=x*;
- cout<<x;
- }
- int main(){
- FO(hanoi);
- //6*???*2^???
- scanf("%d",&n);
- for(int i=;i<;i++)scanf("%s",mov[i]);
- int ans3=luangao();
- if(ans3==)c233();
- else if(ans3==)pow2();
- else if(ans3==)pow3();
- else cout<<"规律不对啊 日";
- }
20160722noip模拟赛alexandrali的更多相关文章
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- NOI模拟赛 Day1
[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...
- NOIP第7场模拟赛题解
NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 小奇模拟赛9.13 by hzwer
2015年9月13日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...
- PKUSC 模拟赛 day1 下午总结
下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...
- [GRYZ]寒假模拟赛
写在前面 这是首次广饶一中的OIERS自编自导,自出自做(zuo)的模拟赛. 鉴于水平气压比较低,机(wei)智(suo)的WMY/XYD/HYXZC就上网FQ下海找了不少水(fei)题,经过他们优( ...
- BZOJ2741: 【FOTILE模拟赛】L
2741: [FOTILE模拟赛]L Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 1170 Solved: 303[Submit][Status] ...
随机推荐
- swift创建对象use of undeclared type 自己的类
在swift项目中,引用自己创建的类,编译会成功的,但是会出现红色感叹号,类似报错,如:swift创建对象use of undeclared type 自己的类,或者 use of unresolv ...
- Xcode中常用的快捷键
各种新建 shift + comand + n 新建xcode项目 option + command + n 新建分组 command + n 新建文件 搜索 shift + command + ...
- WCF之消息模式
请求/响应:所有操作的默认行为,在WSDL中表现为Input/Output元素. One_Way. 在WSDL中只有Input,没有回应(Output),所以没有异常报告. 单向操作只会在发出调用的瞬 ...
- highcharts实现统计图效果
highcharts实现统计图效果 ① 根据需求确定需要使用的案例图 把这个界面的html模板文件复制出来,放入./Application/Admin/View/User下改名为chart.html ...
- .NET中的标识符、关键字 以及 .NET中的命名规范
1.关键字 C#定义了一些关键字(public/static/void/class/int/string),这些关键字是构成C#基本语法用的. VS中蓝色字的才是关键字. Main.String.Co ...
- 6.ipv6地址配置
1. "nmcli connection modify 网卡名 ipv4.addresses "ipv6地址" ipv6.method manual ". 2. ...
- 使用FormData上传文件、图片
关于FormData XMLHttpRequest Level 2添加了一个新的接口 ---- FormData 利用FormData对象,可以通过js用一些键值对来模拟一系列表单控件,可以使用XM ...
- jexus 配置 学习
http://www.linuxdot.net/ 1.禁止或允许某IP或IP段访问网站 A.只允许某些IP地址访问网站(白名单功能) 默认情况下,允许所有IP地址访问.如果手工设置IP地址白名单, 那 ...
- Android 多国语言
参考android 开发文档, ISO 639-1 ISO 3166-1-alpha-2 关于中国的: 中国其他地区: https://en.wikipedia.org/wiki/ISO_3166 ...
- PHP实现根据浏览器跳转不同语言页面代码
以下是对使用PHP实现根据浏览器跳转不同语言页面的代码进行了介绍,需要的朋友可以过来参考下 代码: <?php /** * 根据不同浏览器跳转不同页面 * 来源:www.jbxue.com * ...