立体图

描述

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

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

每个顶点用1个加号‘+’表示,长用3个‘-’表示,宽用1个‘/’表示,高用两个‘|’表示。字符‘+’,‘-’,‘/’,‘|’的ASCII码分别为43,45,47,124。字符‘.’(ASCII码46)需要作为背景输出,即立体图里的空白部分需要用‘.’来代替。立体图的画法如下面的规则:
若两块积木左右相邻,图示为:

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

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

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

格式

输入格式

输入文件drawing.in第一行有用空格隔开的2个整数m和n,表示有m*n个格子(1<=m,n<=50)。

接下来的m行,是一个m*n的矩阵,每行有n个用空格隔开的整数,其中第i行第j列上的整数表示第i行第j列的格子上摞有多少个积木(1<=每个格子上的积木数<=100)。

输出格式

输出文件drawing.out中包含题目要求的立体图,是一个K行L列的字符矩阵,其中K和L表示最少需要K行L列才能按规定输出立体图。

样例1

样例输入1

3 4
2 2 1 2
2 2 1 1
3 2 1 2

样例输出1

......+---+---+...+---+
..+---+ / /|../ /|
./ /|-+---+ |.+---+ |
+---+ |/ /| +-| | +
| | +---+ |/+---+ |/|
| |/ /| +/ /|-+ |
+---+---+ |/+---+ |/| +
| | | +-| | + |/.
| | |/ | |/| +..
+---+---+---+---+ |/...
| | | | | +....
| | | | |/.....
+---+---+---+---+......

限制

各个测试点1s

来源

此题由wangjie添加

题目链接:https://vijos.org/p/1497

分析:首先我们要画出来一个立方体。

 void draw(int x, int y)
{
int i, j;
for(i = y + ; i < y + ; i++)
canvas[x][i] = canvas[x - ][i] = canvas[x - ][i + ] = '-';
for(i = x - ; i > x - ; i--)
canvas[i][y] = canvas[i][y + ] = canvas[i - ][y + ] = '|';
for(i = x - ; i > x - ; i--)
for(j = y + ; j < y + ; j++)
canvas[i][j] = ' ';
for(i = x - ; i > x - ; i--)
canvas[i][y + ] = ' ';
for(i = y + ; i < y + ; i++)
canvas[x - ][i] = ' ';
canvas[x][y] = canvas[x - ][y] = canvas[x][y + ] = canvas[x - ][y + ] = '+';
canvas[x - ][y + ] = canvas[x - ][y + ] = canvas[x - ][y + ] = '/';
canvas[x - ][y + ] = canvas[x - ][y + ] = canvas[x - ][y + ] = '+';
}

draw(x,y)表示从在画布上左小角坐标为x,y画立方体。

实际上也可以用常量定义立方体,然后复制到数组里。

然后我们要确定画布的长和宽。

长比较好求,因为每个格子都回至少有1个立方体,现在就是要确定宽。

 width =  * n +  +  * m;
height = ;
for(i = ; i <= m; i++)
for(j = ; j <= n; j++)
height = max(height, hei[i][j] * + + * (m - i) + );

意思比较好理解了。

hei是每个格子的高度。

height是宽,width是长。

然后初始化画布。

现在就是在哪里画立方体。

 for(i = ; i <= m; i++)
for(j = ; j <= n; j++)
{
for(k = ; k <= hei[i][j]; k++)
draw(height - * (m - i) - ((k-)*), * (j - ) + + (m - i) * );
}

i和j是格子的坐标,k是格子的高度

height-2*(m-i)-((k-1)*3)表示x坐标,4*(j-1)+1+(m-i)*2表示y坐标。

最后打印画布即可。

 #include <stdio.h>
#define max(a,b) (a)>(b)?(a):(b)
#define M 50
#define N 50 int n, m;
int i, j, k;
int p, q;
int width, height;
int hei[M][N];
char canvas[][]; void draw(int x, int y)
{
int i, j;
for(i = y + ; i < y + ; i++)
canvas[x][i] = canvas[x - ][i] = canvas[x - ][i + ] = '-';
for(i = x - ; i > x - ; i--)
canvas[i][y] = canvas[i][y + ] = canvas[i - ][y + ] = '|';
for(i = x - ; i > x - ; i--)
for(j = y + ; j < y + ; j++)
canvas[i][j] = ' ';
for(i = x - ; i > x - ; i--)
canvas[i][y + ] = ' ';
for(i = y + ; i < y + ; i++)
canvas[x - ][i] = ' ';
canvas[x][y] = canvas[x - ][y] = canvas[x][y + ] = canvas[x - ][y + ] = '+';
canvas[x - ][y + ] = canvas[x - ][y + ] = canvas[x - ][y + ] = '/';
canvas[x - ][y + ] = canvas[x - ][y + ] = canvas[x - ][y + ] = '+';
} int main()
{
scanf("%d%d", &m, &n);
for(i = ; i <= m; i++)
for(j = ; j <= n; j++)
scanf("%d", &hei[i][j]);
width = * n + + * m;
height = ;
for(i = ; i <= m; i++)
for(j = ; j <= n; j++)
height = max(height, hei[i][j] * + + * (m - i) + );
for(i = ; i <= height; i++)
for(j = ; j <= width; j++)
canvas[i][j] = '.';
for(i = ; i <= m; i++)
for(j = ; j <= n; j++)
{
for(k = ; k <= hei[i][j]; k++)
draw(height - * (m - i) - ((k-)*), * (j - ) + + (m - i) * );
}
for(p = ; p <= height; p++)
{
for(q = ; q <= width; q++)
putchar(canvas[p][q]);
putchar('\n');
}
return ;
}

最新文章

  1. mysql+ssh 配置(转载)
  2. iOS 版 MWeb 发布到自建 Wordpress 和 Metaweblog API 使用指南
  3. GridView 和DataGrid区别
  4. php的amqp扩展set导致内存溢出
  5. SQL合并时间段的问题
  6. js获取get值
  7. hdu 5245 Joyful(期望的计算,好题)
  8. PHP学习笔记十一【数组】
  9. 关于Ubuntu12.04下code::blocks不能使用debug解决方法
  10. 第一百二十七节,JavaScript,JSON数据类型转换,数据转换成字符串,字符串转换成数据
  11. http请求连接
  12. 【JAVA零基础入门系列】Day7 Java输入与输出
  13. fread和fwrite的使用
  14. 接触JS的变量
  15. LeetCode之“动态规划”:Minimum Path Sum &amp;&amp; Unique Paths &amp;&amp; Unique Paths II
  16. select 与 time.After 配合使用的问题
  17. 【PyTorch深度学习60分钟快速入门 】Part1:PyTorch是什么?
  18. MVC架构介绍-事件机制
  19. hdu-4738-tarjin/割边
  20. ActiveMQ broker和客户端之间的确认

热门文章

  1. Solr集群搭建详细教程(二)
  2. JavaWeb项目之电话本,两个版本,以及总结反思
  3. mysql 先分组在排序
  4. [置顶] android ListView包含Checkbox滑动时状态改变
  5. ArcGIS 网络分析[1.4] 制作点线要素时需要注意的地方
  6. (一)DOM 常用操作 —— “查找”节点
  7. WebDriver API 大全
  8. ssh简明安全规划
  9. 原生 js 实现点击按钮复制文本
  10. python重试装饰器的简单实现