题目:
小凡有一张边长为2的正方形白纸,上面画了2×2个边长为1的格子,每个格子上可以放置棱长为1的立方体。小凡手中有若干个棱长为1的立方体,他随机地在每个格子上放置一些立方体,求由这些立方体组成的几何体的表面积。
输入格式:
输入两行,每行两个不超过100的正整数,代表从俯视的角度看,白纸所画每个格子上立方体的数量。
输出格式:
输出一行,包含一个整数,表示几何体的表面积。
输入样例:
上图对应的输入数据如下:
2 1
1 1
输出样例:
20
题解:
这题别读假题!一定要理清楚题意。
首先,必定至少有2x2个方块(注意和2x2x2的区别)作为底面。
那么这样的话,底部必定为4,上面无论几个,俯视图必定也为4
也就是只需要观察前后左右各个面的面积,求其和+8,即为最终结果。
对前面和后面,取竖排二者最大,计算面积为x+y(因为1* x+1* y)这样再乘2
对左右,取横排二者最大,计算面积,同理乘2
c++代码:
#include<bits/stdc++.h>
using namespace std;
int main(){
int a,b,c,d;
cin>>a>>b>>c>>d;
int res=0;
res+=8; //8是上下两面的面积和
res+=(max(a,b)+max(c,d))*2+(max(a,c)+max(b,d))*2;
cout<<res<<'\n';
return 0;
}
然后提一下这里用c写与c++的区别:
1. 上面两行自动忽略,换成常用的stdio就行
2.cin自动换scanf()函数,cout自动换printf()函数
3.max()和min()函数记得自己写就行。
后话:
这道题审题很重要,更重要的是:
如何把一个问题给拆分细化成小问题,然后再着手解决。
这个思想非常重要,一定要熟练,刻在DNA!