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



样例:

输出样例:

(洛谷上面的那个太丑了就不放了)
乍一看好像真的没有什么思路
所以我们结合ybr大佬的代码进行分析
疑点都将在代码下面进行分析(面对代码做题模式开始)
#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];//为什么从1开始?因为考虑到不在立方体内的空格要变成"."
for(int i=;i<=;i++)c[zbx+][zby+i]=c1[][i];//从2开始同上
}
int main()
{
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+;//我不知道为什么 (by ybr)(下面有解释)
if(zby+>maxl)maxl=zby+;
}
for(int i=maxh;i>=;i--)//上面计算zbx是默认原点是(1,1),不是(0,0)
{
for(int j=;j<=maxl;j++)
{
if(c[i][j]=='\0') printf(".");//如果c[i][j]没有被覆盖过,就输出"."
else
printf("%c",c[i][j]);
}
printf("\n");
}
return ;
}
难点:1:zbx,zby是个啥玩意?
(zbx,zby)枚举当前的这个块的左下角在输出的图中的坐标

就是枚举这个蓝点辣
注意我们把最终输出的立体图当做二维图来看

推导:
zbx:(我们先考虑只有一层的情况)

我们注意到,一个字符在上面的x轴上的贡献是1,(x轴就是上面说的x轴)
m-i:

(不要在意没有画完的最右边)
从上图看出来,m-i就是m和i隔着几“行”,其中,一“行”在x轴上的贡献是2,所以要(m-i)*2,因为一个块的边对x的贡献都是2,我们要先+2,再-2,就抵消了。
又因为下标是从1开始计算,所以要+1
每往上摞一层,zbx就要+3(一层对x轴的贡献是3)
zby:

我们拿那个蓝色的方块举例。
因为一个方块在y轴方向上的贡献是4(这里的贡献不会重复计算),所以不考虑"."的贡献,当前的zby是(j-1)*4+1
再通过肉眼观察,发现在输出图中,是"+"的那一行最左边的"."的数量都是偶数,“.”对y轴的贡献是(m-i)*2
难点2:maxh?maxl?为毛这俩的更新方法如此玄学?
ybr:我也不知道为什么
咳咳我们来研究一下这个玄学的问题
窝盟先来分析一下zby+6是个什么鬼
分析如下:

一张手动补全的图
我们看到,在第一行的方块左下角在y轴上的坐标+6就是最终输出图的最右端
zbx+2:
由于代码在执行取maxh,maxl之前有以下神奇的操作
for(int k=;k<=jz[i][j];k++,zbx+=3)
{
fg(zbx,zby);
}
这就是看每一个格子上面有几个方块
在执行完神奇的操作之后,原本表示左下角的zbx变成了左上角(可以手画一下)
由于一个
在x轴上的贡献是2,所以是zbx+2
难点3:这是什么存储方法怎么好像是倒着的?
它的确是倒着的
难点4:这是什么个覆盖顺序???
从后往前枚举(i是从1到m,因为第1行在最里面),从左往右枚举,从下往上枚举
好了解释完了qwq(逃
P1058立体图(面对代码解释)的更多相关文章
- Deep Learning入门视频(下)之关于《感受神经网络》两节中的代码解释
代码1如下: #深度学习入门课程之感受神经网络(上)代码解释: import numpy as np import matplotlib.pyplot as plt #matplotlib是一个库,p ...
- [ARM] Cortex-M Startup.s启动文件相关代码解释
1. 定义一个段名为CSTACK, 这里: NOROOT表示如何定义的段没有被关联,那么同意会被优化掉,如果不想被优化掉就使用ROOT. 后面的括号里数字表示如下: (1):这个段是2的1次方即2字节 ...
- word2vec代码解释
以前看的国外的一篇文章,用代码解释word2vec训练过程,觉得写的不错,转过来了 原文链接 http://nbviewer.jupyter.org/github/dolaameng/tutorial ...
- 通过代码解释什么是API,什么是SDK?
这个问题说来惭愧,读书时找实习面的第一家公司,问的第一个问题就是这个. 当时我没能说清楚,回去之后就上百度查.结果查了很久还是看不懂,然后就把这个问题搁置了. 谁知道毕业正式工作后,又再一次地面对了这 ...
- javascript代码解释执行过程
javascript是由浏览器解释执行的脚本语言,不同于java c,需要先编译后运行,javascript 由浏览器js解释器进行解释执行,总的过程分为两大块,预编译期和执行期 下面的几个demo解 ...
- 临时2级页表的初始化过程 head_32.S 相关代码解释
page_pde_offset = (__PAGE_OFFSET >> 20); /* __PAGE_OFFSET是0xc0000000,page_pde_offset = 3072 = ...
- 零基础学python之入门和列表数据(附详细的代码解释和执行结果截图)
Python学习笔记 1 快速入门 下载安装好Python之后,在开始找到 双击打开一个窗口,这是一个shell界面编辑窗口,点击左上角的file——new file新建一个窗口,这里可以输入完整的代 ...
- java 的一个hellow word 代码解释
/* This is a simple Java program. Call this file "Example.java". */(上面是注释的方法) class Exampl ...
- TensorFlow的序列模型代码解释(RNN、LSTM)---笔记(16)
1.学习单步的RNN:RNNCell.BasicRNNCell.BasicLSTMCell.LSTMCell.GRUCell (1)RNNCell 如果要学习TensorFlow中的RNN,第一站应该 ...
随机推荐
- IIS下如何配置免费的https
1.首先我们要取走我们的证书,保存在我们本地的电脑里,然后复制到服务器即可. 2.取走后接下来干嘛?当然是打开文件看看里面有些什么啊.我们找到IIS那个压缩包并解压. 3.解析得到pfx文件,也就是我 ...
- C# DropDownList绑定添加新数据的三种方法
一.在前台手动绑定 <asp:DropDownList ID="DropDownList1" runat="server"> <asp: ...
- STM32 RTC
目前较为实用的RTC时钟源选择的是:32.768k LSE 低速外部时钟: 不建议实用LSI,精度不高,对时间精度要求不高的可以考虑实用LSI时钟源.数据手册上电气特性的数据:
- 从头到尾说一次 Java 垃圾回收,写得非常好!
Java技术栈 www.javastack.cn 优秀的Java技术公众号 作者:聂晓龙(花名:率鸽),阿里巴巴高级开发工程 ⬆️ 图片来源于网络 之前上学的时候有这个一个梗,说在食堂里吃饭,吃完把餐 ...
- 第二次java面试(用友山东济南分公司)
坐标:山东潍坊公共实训基地 面试单位:用友济南分公司(来了一位HR和技术经理) 本人状态:距离离校15天 宣讲: 1.女HR和男技术经理来到我们专业提前准备好的教室,先宣传海报和发传单,然后看了4个3 ...
- Count Color poj2777 线段树
Count Color poj2777 线段树 题意 有一个长木板,现在往上面在一定区间内刷颜色,后来刷的颜色会掩盖掉前面刷的颜色,问每次一定区间内可以看到多少种颜色. 解题思路 这里使用线段树,因为 ...
- C89标准和C99标准C11标准的区别
转载 C89标准和C99标准C11标准的区别 C99对C89的改变 1.增加restrict指针 C99中增加了公适用于指针的restrict类型修饰符,它是初始访问指针所指对象的惟一途径,因此只有借 ...
- C# 反射实现动态加载程序集
原文:https://blog.csdn.net/pengdayong77/article/details/47622235 在.Net 中,程序集(Assembly)中保存了元数据(MetaData ...
- 对于call,apply,bind 的理解
JavaScript 中 call().apply().bind() 的用法 之前对与JavaScript中的call,apply,bind这几个方法一直理解的很模糊,今天总结一下. 例1 var n ...
- HashMap、Hashtable和ConcurrentHashMap的区别
HashTable 底层数组+链表实现,无论key还是value都不能为null,线程安全,实现线程安全的方式是在修改数据时锁住整个HashTable,效率低,ConcurrentHashMap做了相 ...