小渊是个聪明的孩子,他经常会给周围的小朋友们将写自己认为有趣的内容。最近,他准备给小朋友们讲解立体图,请你帮他画出立体图。

小渊有一块面积为m \times nm×n的矩形区域,上面有m \times nm×n个边长为11的格子,每个格子上堆了一些同样大小的积木(积木的长宽高都是11),小渊想请你打印出这些格子的立体图。我们定义每个积木为如下格式,并且不会做任何翻转旋转,只会严格以这一种形式摆放:

每个顶点用11个加号’++’表示,长用33个”-−”表示,宽用11个”/”,高用两个”|”表示。字符’++’,”-−”,”/”,”|”的ASCIIASCII码分别为4343,4545,4747,124124。字符’.’(ASCIIASCII码4646)需要作为背景输出,即立体图里的空白部分需要用’.’来代替。立体图的画法如下面的规则:

若两块积木左右相邻,图示为:

若两块积木上下相邻,图示为:

若两块积木前后相邻,图示为:

立体图中,定义位于第(m,1(m,1)的格子(即第mm行第11列的格子)上面自底向上的第一块积木(即最下面的一块积木)的左下角顶点为整张图最左下角的点。

输入输出格式

输入格式:

第一行有用空格隔开的22个整数mm和nn,表示有m \times nm×n个格子(1 \le m,n \le 50)(1≤m,n≤50)。

接下来的mm行,是一个m \times nm×n的矩阵,每行有nn个用空格隔开的整数,其中第ii行第jj列上的整数表示第ii行第jj列的个子上摞有多少个积木(1 \le1≤每个格子上的积木数\le 100≤100)。

输出格式:

输出包含题目要求的立体图,是一个KK行LL列的字符串矩阵,其中KK和LL表示最少需要KK行LL列才能按规定输出立体图。


题解部分:

题都读不懂?

其实就是给你长宽,给你三视图(主,侧,俯)中的俯视图,然后让你画它的三维立体图。

本题思路源泉:P1003 铺地毯

也就是一个覆盖的思想。

众所周知,三维图要满足遮挡关系,也就是前面的遮挡后面的,右面的遮挡左边的。

那么我们用透视关系来覆盖。

那么我们枚举每一个二维方块位置,然后在每一个二维平面位置上一个一个网上摞方块就可以了。

具体的,因为每一个方块为一个面积,那么我们只能抽象成一个点来进行枚举

我们把一个方块抽象为左上角的点,于是枚举左上角的点再进行覆盖。

这个题就这样了。。

代码:

#include<cstdio>
#include<iostream>
using namespace std;
int read(){
int ans=;
char last=' ',ch=getchar();
while(ch<''||ch>'')
last=ch,ch=getchar();
while(ch>=''&&ch<='')
{
ans=(ans<<)+(ans<<)+(ch^);
ch=getchar();
}
return last=='-'?-ans:ans;
}
char c[][],c1[][]={//倒着存储
"+---+",
"| |/",
"| | +",
"+---+ |",
" / /|",
" +---+",
};//6行7列 的方块
int n,m,jz[][],maxh=-,maxl=-,zbx,zby;
inline void fg(int zbx,int zby)//覆盖操作
{
for(int i=;i<=;i++)c[zbx][zby+i]=c1[][i];
for(int i=;i<=;i++)c[zbx+][zby+i]=c1[][i];
for(int i=;i<=;i++)c[zbx+][zby+i]=c1[][i];
for(int i=;i<=;i++)c[zbx+][zby+i]=c1[][i];
for(int i=;i<=;i++)c[zbx+][zby+i]=c1[][i];
for(int i=;i<=;i++)c[zbx+][zby+i]=c1[][i];
}
int main(){
// freopen("drawing.in","r",stdin);
// freopen("drawing.out","w",stdout);
m=read();n=read();
for(int i=;i<=m;i++)
{
for(int j=;j<=n;j++)
{
jz[i][j]=read();
}
}
for(int i=;i<=m;i++)//从输入的矩阵的左上角开始,满足先后,先左
for(int j=;j<=n;j++)
{
zbx=(m-i)*+;zby=(m-i)*++*(j-);
for(int k=;k<=jz[i][j];k++,zbx+=)
{
fg(zbx,zby);
}
if(zbx+>maxh)maxh=zbx+;//我不知道为什么
if(zby+>maxl)maxl=zby+;
}
for(int i=maxh;i>=;i--)
{
for(int j=;j<=maxl;j++)
{
if(c[i][j]=='\0') printf(".");
else
printf("%c",c[i][j]);
}
printf("\n");
}
return ;
}

完结

P1058 立体图题解的更多相关文章

  1. P1058立体图

    一道大模拟 思路: 首先是打表找规律时间 仔细思考(暴力手算)后推出这么一个数组: //宽的增加量 ]={,,,};//1竖着摞,2横着摞,3前后摞 //长的增加量 ]={,,,};//1竖着摞,2横 ...

  2. P1058立体图(面对代码解释)

    传送 样例: 输出样例: (洛谷上面的那个太丑了就不放了) 大佬博客在此 乍一看好像真的没有什么思路 所以我们结合ybr大佬的代码进行分析 疑点都将在代码下面进行分析(面对代码做题模式开始) #inc ...

  3. luogu P1058 立体图

    做了这个题后明确了自己的定位... 恩...普及- 题目大意估计都知道.. 给个传送门:   luogu 做了半上午 + 一整个下午的题... 占了我今天到的绝大多数时间. 其实此题不难, 核心代码我 ...

  4. P1058 立体图

    链接:Miku ------------------------------ 蒟蒻在线%lmk,ljx,lpy,yyq大佬们 ------------------------------ Good N ...

  5. NOIP 2008 立体图

    洛谷 P1058 立体图 洛谷传送门 JDOJ 1541: [NOIP2008]立体图 T4 JDOJ传送门 题目描述 小渊是个聪明的孩子,他经常会给周围的小朋友们将写自己认为有趣的内容.最近,他准备 ...

  6. 模拟画图题P1185 绘制二叉树

      题目链接P1185 绘制二叉树 题意概述   根据规则绘制一棵被删去部分节点的满二叉树.节点用 \(o\) 表示,树枝用/\表示.每一层树枝长度会变化,以满足叶子结点有如下特定: 相邻叶子节点是兄 ...

  7. 2019.7.12 sdfzoier做题统计

    lixf_lixf :9 P1981 表达式求值 P1076 寻宝 P1199 三国游戏 P1308 统计单词数 P1190 接水问题 P1158 导弹拦截 P1070 道路游戏 P1069 细胞分裂 ...

  8. 【洛谷p1058】立体图(已完结)

    立体图[题目链接] 然后因为有点(不是有点,非常)懵,因此我只能看一步写一步. 首先总体思路: 将三维立体图看做二维平面图,先确定出二维图的长和宽,然后,按照三维立体图的透视顺序,从最后一排的最左开始 ...

  9. NOIP2008普及组题解

    NOIP2008普及组题解 从我在其他站的博客直接搬过来的 posted @ 2016-04-16 01:11 然后我又搬回博客园了233333 posted @ 2016-06-05 19:19 T ...

随机推荐

  1. 通过Precision/Recall判断分类结果偏差极大时算法的性能

    当我们对某些问题进行分类时,真实结果的分布会有明显偏差. 例如对是否患癌症进行分类,testing set 中可能只有0.5%的人患了癌症. 此时如果直接数误分类数的话,那么一个每次都预测人没有癌症的 ...

  2. 阶段3 3.SpringMVC·_01.SpringMVC概述及入门案例_04.入门程序之搭建开发环境

    选择骨架构建 默认选中next-然后finish后就会去网上下载插件.会比较耗费时间. 添加一组键值对: archetypeCatalog internal 添加了这组坚持对,就可以解决Mavn项目创 ...

  3. 如何实现在Eclipse导入c3p0

    1 右键项目->Properties->Java Build Path->Libraries->Add External JARs...-> c3p0-0.9.5.2.j ...

  4. 【myeclipse2014-2017】使用相关

    1.窗口背景颜色修改 2.javascript代码块背景颜色修改 3.控制台颜色相关 4.myeclipse主题相关 5.myeclipse清除项目缓存 (1.删除work中的文件.2.删除wabap ...

  5. PHP 异步执行方式

    在工作中我们经常遇到一些比较耗时的任务,比如用户注册发送邮件,审核短信通知等功能,同步执行这些功能的话,响应时间就会变长,所以一般我们会用队列去管理这些功能,但是如果条件不允许怎么办,今天get了一个 ...

  6. shell脚本判断里面的字符含义

    [ -s FILE ] 如果 FILE 存在且大小不为0则为真. [ -a FILE ] 如果 FILE 存在则为真. [ -b FILE ] 如果 FILE 存在且是一个块特殊文件则为真. [ -c ...

  7. k8s-kubernettes-sercet存储

    Secret Secret存在意义 Secret解决了密码.token.密钥等敏感数据的配置问题,而不需要把这些敏感数据暴露到镜像或者Pod Spec中.Secret可以以Volume或者环境变量的方 ...

  8. C语言I博客作业12

    一.我学到的内容 二.我的收获 作业链接 收获 博客第一次作业:https://www.cnblogs.com/gm12/p/11584148.html 第一次作业收获:第一次作业是我初步接触C语言的 ...

  9. Node.js使用redis进行订阅发布管理

    redis NPM 官方介绍地址:https://www.npmjs.com/package/redis let redis = require('redis'); let subscriber; l ...

  10. Hbase 三维存储

    hbase所谓的三维有序存储的三维是指:rowkey(行主键),column key(columnFamily+qualifier),timestamp(时间戳)三部分组成的三维有序存储. 1.row ...