P1185【绿】
这道题是画图题,画图题当画布总大小较小的时候其实可以先创建一个二维数组,这样就可以实现随意移动“光标”式的画图,然后直接输出处理后的画布即可,只要注意题目要求的数据范围足够小、画布不会让你的程序MLE就行。
但我做这道题的时候忘了这个,直接用比较麻烦的办法做的,但是由于使用了OOP来描述树和一个队列来管理树枝,整体代码清晰度也很高,就是长了一些。
但是写成后发现只得了89分,WA了一个点。调试后发现是因为我对一个空队列使用了front()成员函数,下次一定要注意,访问STL的数据结构内的数据的时候要确保其中有数据,否则就会出错,偏偏不知道为什么没有抛出异常、至少没有报错。总之下次引用front()时最好在前面加一个!q.empty()&&利用&&的短路属性来防止访问不存在的量。
但是更改后还是只有89分,没想明白错在哪里
结果,一位乐于助人的洛谷大佬给出了hack数据,根据对这个数据标答和我的答案不同的输出我发现我可以尝试删除“m=T.setd();//更新树的深度”这一行,结果我简单的删除了那一行就直接AC了。看来是对题意的理解不同,不过我重新读了一遍题之后发现题意其实没说清这块,而且我的代码这种删除后更新树的深度的方式其实更接近于合理的理解,数据的理解则是像是没考虑到更新树的深度一样。不过就这样吧,这题解决了。
收获:1.画图函数数据范围不大就考虑用画布数组,这样能大大降低思维复杂度
2、STL结构用完后别忘了清空,同时数据结构可能为空的情况下不要贸然访问!加一个判断是否为空的步骤!
3、多读题,确保对题意理解没有偏差,一字一句的读,不差这点时间!
89昏-Code
#include <iostream>
#include <cstdio>
#include <string>
#include <queue>
using namespace std;
int c[100],l[100],d[100],pow2[100],n,m,a,b;
int intpow(int a,int b)
{
int ans=1;
for(int i=1;i<=b;i++)ans*=a;
return ans;
}
struct tree
{
int t[2000];
int d,e;
void start(int D)
{
d=D;e=intpow(2,d)-1;
for(int i=1;i<=e;i++)t[i]=1;
}
void del(int P)
{
t[P]=0;
if(P*2+1<=e)
{
del(P*2);
del(P*2+1);
}
}
int setd()
{
int i;
for(i=e;i>=1;i--)
if(t[i]==1)
break;
while(i<=(e+1)/2-1)e=(e+1)/2-1,d--;
return d;
}
int isexisted(int a,int b)
{
if(t[intpow(2,a-1)-1+b]==1)return 1;
else return 0;
}
int isexisted(int no)
{
if(t[no]==1)return 1;
else return 0;
}
}T;
queue<int> Ql,Qr,nQl,nQr;
int main()
{
cin>>m>>n;
T.start(m);
for(int i=1;i<=n;i++)
{
cin>>a>>b;
T.del(intpow(2,a-1)-1+b);
}
m=T.setd();
l[1]=1;l[2]=5;c[1]=1;c[2]=3;d[1]=2;d[2]=3;pow2[0]=1,pow2[1]=2,pow2[2]=4;
for(int i=3;i<=m;i++)
l[i]=l[i-1]*2+1,c[i]=c[i-1]*2,d[i]=d[i-1]*2,pow2[i]=pow2[i-1]*2;
for(int i=1,p=1,lno=m,kno=m-1,no=1;i<=c[m];i++)
{
if(i==c[m])
{
string s="o ";if(m==1)s="o";
for(int q=1;q<=pow2[no-1];q++)
{
for(int j=1;j<=(l[lno]-1)/2;j++)cout<<' ';
if(T.isexisted(no,q)==1)cout<<s;else cout<<" ";//no是层,q是层内序号
for(int j=1;j<=(l[lno]-1)/2;j++)cout<<' ';
if(q!=pow2[no-1])cout<<' ';
if(s=="o ")s=" o";else s="o ";
}
}
else if(i==p)
{
while(!Ql.empty())Ql.pop();
while(!Qr.empty())Qr.pop();
for(int q=1,t=1;q<=pow2[no-1];q++)
{
for(int j=1;j<=(l[lno]-1)/2;j++)cout<<' ',t++;
if(T.isexisted(no,q)==1)
{
cout<<"o";
if(T.isexisted((intpow(2,no-1)-1+q)*2)==1)Ql.push(t-1);
if(T.isexisted((intpow(2,no-1)-1+q)*2+1)==1)Qr.push(t+1);
t++;
}
else
cout<<' ',t++;//no是层,q是层内序号
for(int j=1;j<=(l[lno]-1)/2;j++)cout<<' ',t++;
if(q!=pow2[no-1])cout<<' ',t++;
}
cout<<endl;
p+=d[kno];
kno--;
lno--;
no++;
}
else
{
for(int j=1;j<=l[m];j++)
{
if(!Ql.empty()&&j==Ql.front())cout<<'/',nQl.push(Ql.front()-1),Ql.pop();
else if(!Qr.empty()&&j==Qr.front())cout<<'\\',nQr.push(Qr.front()+1),Qr.pop();
else cout<<' ';
}
cout<<endl;
Ql=nQl;Qr=nQr;
while(!nQl.empty())nQl.pop();
while(!nQr.empty())nQr.pop();
}
}
return 0;
}
AC-Code
#include <iostream>
#include <cstdio>
#include <string>
#include <queue>
using namespace std;
int c[20],l[20],d[20],pow2[20],n,m,a,b;
int intpow(int a,int b)//乘方运算函数
{
int ans=1;
for(int i=1;i<=b;i++)ans*=a;
return ans;
}
struct tree
{
int t[1030];
int d,e;
void start(int D)
{
d=D;e=intpow(2,d)-1;
for(int i=1;i<=e;i++)t[i]=1;
}
void del(int P)
{
t[P]=0;
if(P*2+1<=e)
{
del(P*2);
del(P*2+1);
}
}
int setd()
{
int i;
for(i=e;i>=1;i--)
if(t[i]==1)
break;
while(i<=(e+1)/2-1)e=(e+1)/2-1,d--;
return d;
}
int isexisted(int a,int b)
{
if(t[intpow(2,a-1)-1+b]==1)return 1;
else return 0;
}
int isexisted(int no)
{
if(t[no]==1)return 1;
else return 0;
}
}T;
queue<int> Ql,Qr,nQl,nQr;
int main()
{
std::ios::sync_with_stdio(false);
std::cin.tie(0); //加速IO用的,不要在意这两行
cin>>m>>n;
T.start(m);//初始化树
for(int i=1;i<=n;i++)
{
cin>>a>>b;
T.del(intpow(2,a-1)-1+b);
}
//m=T.setd();//更新树的深度
//辅助数组
l[1]=1;l[2]=5;c[1]=1;c[2]=3;d[1]=2;d[2]=3;pow2[0]=1,pow2[1]=2,pow2[2]=4;
for(int i=3;i<=m;i++)
l[i]=l[i-1]*2+1,c[i]=c[i-1]*2,d[i]=d[i-1]*2,pow2[i]=pow2[i-1]*2;
//没有画布数组,直接把结果按顺序输出
for(int i=1,p=1,lno=m,kno=m-1,no=1;i<=c[m];i++)
{
if(i==c[m])
{
string s="o ";if(m==1)s="o";
for(int q=1;q<=pow2[no-1];q++)
{
for(int j=1;j<=(l[lno]-1)/2;j++)cout<<' ';
if(T.isexisted(no,q)==1)cout<<s;else cout<<" ";//no是层,q是层内序号
for(int j=1;j<=(l[lno]-1)/2;j++)cout<<' ';
if(q!=pow2[no-1])cout<<' ';
if(s=="o ")s=" o";else s="o ";
}
}
else if(i==p)
{
while(!Ql.empty())Ql.pop();
while(!Qr.empty())Qr.pop();
for(int q=1,t=1;q<=pow2[no-1];q++)
{
for(int j=1;j<=(l[lno]-1)/2;j++)cout<<' ',t++;
if(T.isexisted(no,q)==1)
{
cout<<"o";
if(T.isexisted((intpow(2,no-1)-1+q)*2)==1)Ql.push(t-1);
if(T.isexisted((intpow(2,no-1)-1+q)*2+1)==1)Qr.push(t+1);
t++;
}
else
cout<<' ',t++;//no是层,q是层内序号
for(int j=1;j<=(l[lno]-1)/2;j++)cout<<' ',t++;
if(q!=pow2[no-1])cout<<' ',t++;
}
cout<<endl;
p+=d[kno];
kno--;
lno--;
no++;
}
else
{
for(int j=1;j<=l[m];j++)
{
if(!Ql.empty()&&j==Ql.front())cout<<'/',nQl.push(Ql.front()-1),Ql.pop();
else if(!Qr.empty()&&j==Qr.front())cout<<'\\',nQr.push(Qr.front()+1),Qr.pop();
else cout<<' ';
}
cout<<endl;
Ql=nQl;Qr=nQr;
while(!nQl.empty())nQl.pop();
while(!nQr.empty())nQr.pop();
}
}
return 0;
}
P1185【绿】的更多相关文章
- 如何优雅使用Sublime Text3(Sublime设置豆沙绿背景色和自定义主题)
♣Sublime Text3软件的下载 ♣设置字体的大小 ♣设置背景色和关键字颜色(Color Scheme 生成器) ♣快速生成html头文件 1.Sublime Text3软件的下载地址和包含的文 ...
- Adobe Reader/Acrobat修改页面底色为豆沙绿
Adobe Acrobat_Pro_8修改PDF页面底色为豆沙绿保护视力(同样适用于Adobe Reader) http://jingyan.baidu.com/article/9989c746189 ...
- 通过sougou输入法,解决卡在Setup Wizard(小绿人)界面
本人使用海信EG900手机(安卓2.3.5,已root),为了使用google的服务,先后手动复制和CWM recovery刷入google服务包(gapps-gb-20110828-signed.z ...
- 紫橙绿蓝的jQuery幻灯片切换
效果展示 http://hovertree.com/texiao/jquery/77/ 看惯了左右切换的幻灯片,何问起向您推荐一个新颖的,旋转切换,通过点击按钮的相应区域可以使幻灯片以旋转的方式来 ...
- Win7下如何设置护眼的电脑豆沙绿界面?保护眼睛的颜色设置教程
关爱心灵的窗户——眼睛! 随着科技发展,使用电脑的人越来越多,由于使用电脑时间过长,我们的眼睛也越发容易疲劳,干燥.如何才能使电脑对人眼的伤害减小到最 小. 小编建议大家可以把窗口背景色设置成护眼色. ...
- 傻瓜式十分钟免费开启 HTTPS,是时候为你的站点加上小绿锁了
http://gold.xitu.io/entry/57df65690bd1d00057f9455b?from=singlemessage&isappinstalled=0 原文链接:http ...
- WPF:定制Checkbox样式,让“正确”绿得好看,让“错误”红的显眼
WPF提供了样式.模板.触发器.状态管理.矢量形状等方式,让我们不需要背景图片,也可以轻松定制控件的风格样式.下面是笔者针对Checkbox进行的样式定制,让“正确”绿得好看,让“错误”红的显眼. ...
- QQMusic绿钻兄,你可安好?我需要晴天。
不好意思,年纪这样大了,还依靠吐槽来保持呆毛的正能量,实在对不住,先说对不起. QQMusic是我最喜欢的腾讯增值服务,正版内容,海量歌手,高清下载.实在是音乐软件中高大上的典范,除了歌手排名中前十中 ...
- [汇编语言]-第九章 在屏幕中间分别显示绿底红色,白底蓝色字符串"welcome to masm!"
;在屏幕中间分别显示绿色,绿底红色,白底蓝色字符串"welcome to masm!" assume cs:codesg,ds:datasg,ss:stacksg datasg s ...
- 刷爆github小绿点
转载请注明出处:https://ahangchen.gitbooks.io/windy-afternoon/content/kit/git/green_blush.html 工程地址,欢迎star!! ...
随机推荐
- vertx 的http服务表单提交与mysql验证
1.依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http:/ ...
- Winform 好看控件库推荐:MaterialSkin.2
MaterialSkin.2 控件包是在 MaterialSkin 及基础上二次开发而来的,在原控件基础上修复了一些Bug,丰富了主题以及动画效果,效果非常好. MaterialSkin.2 现在处于 ...
- 【matlab混沌理论】1.1.混沌理论简介
混沌理论 1.简介 混沌理论是一个跨学科的科学研究领域和数学分支,专注于对初始条件高度敏感的动力系统的基本模式和确定性定律,曾被认为具有完全随机的无序和不规则状态.混沌理论指出,在混 ...
- Taurus .Net Core 微服务开源框架:Admin 插件【4-8】 - 配置管理-Mvc【Plugin-Limit 接口访问限制、IP限制、Ack限制】
前言: 继上篇:Taurus .Net Core 微服务开源框架:Admin 插件[4-7] - 配置管理-Mvc[Plugin-Metric 接口调用次数统计] 本篇继续介绍下一个内容: 1.系统配 ...
- MinIO客户端之diff
MinIO提供了一个命令行程序mc用于协助用户完成日常的维护.管理类工作. 官方资料 mc diff 检查指定桶内对象清单的差异,注意不比较对象内容的差异,命令如下: ./mc diff local1 ...
- ElasticSearch之cat nodeattrs API
命令样例如下: curl -X GET "https://localhost:9200/_cat/nodeattrs?v=true&pretty" --cacert $ES ...
- ElasticSearch之cat component templates API
命令样例如下: curl -X GET "https://localhost:9200/_cat/component_templates?v=true&pretty" -- ...
- ElasticSearch之cat aliases API
执行aliases命令,如下: curl -X GET "https://localhost:9200/_cat/aliases?pretty&v=true" --cace ...
- 『Flutter』开篇
什么是 Flutter Flutter 是由 Google 开发的开源框架 Flutter 用于构建跨平台的移动应用程序 Flutter 它允许开发者使用同一套代码来同时为 IOS 和 Android ...
- GeoServer发布地图服务(WMS、WFS)
目录 1. 概述 2. 矢量数据源 3. 栅格数据源 1. 概述 我们知道将GIS数据大致分成矢量数据和栅格数据(地形和三维模型都是兼具矢量和栅格数据的特性).但是如果用来Web环境中,那么使用图片这 ...