HDU

空心三角形

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 43808    Accepted Submission(s): 12000

 

Problem Description
把一个字符三角形掏空,就能节省材料成本,减轻重量,但关键是为了追求另一种视觉效果。在设计的过程中,需要给出各种花纹的材料和大小尺寸的三角形样板,通过电脑临时做出来,以便看看效果。
 
Input
每行包含一个字符和一个整数n(0<n<41),不同的字符表示不同的花纹,整数n表示等腰三角形的高。显然其底边长为2n-1。如果遇到@字符,则表示所做出来的样板三角形已经够了。
 
Output
每个样板三角形之间应空上一行,三角形的中间为空。显然行末没有多余的空格。
 
Sample Input
X 2 A 7 @
 
Sample Output
X XXX   A A A A A A A A A A A AAAAAAAAAAAAA
 
 
 
题意很简单,就是输出空心三角形而已,方法有很多,此博客就是为了吸取一下教训。
 
题目输出中说“每个样板三角形之间应该空上一行”,这就有意思了,我一开始以为就是两个换行就可以了,结果Presentation Error,搞得我以为代码出问题了呢,de了半天bug。后来才发现原来是在输出样本三角形之前加一个换行就可以了(除去第一个样本三角形)。
 
分享AC代码:
 
 1 /*
 2  *   > File Name: HDU2091.cpp
 3  *   > Author: Ddlm2wxm
 4  *   > Mail: Ddlm2wxm@163.com
 5  *   > Created Time: 2017/3/8 13:40:14
 6   *****************************************/
 7 
 8 #include <iostream>
 9 #include <algorithm>
10 #include <string>
11 #include <cstring>
12 #include <cstdio>
13 using namespace std;
14 
15 int main() {
16     int n;
17     bool flag = false;
18     char a;
19     while (cin >> a && a != '@' && cin >> n) {
20         if(flag) cout << endl;
21         flag = true;    // 第一次不输出换行,以后的都在输出三角形之前输出换行.
22         for (int i = 0; i < n-1; ++i) {
23             for (int j = n-i-1; j > 0; --j) {
24                 cout << " ";
25             }
26             for (int j = 0; j < 2*i+1; ++j) {
27                 if ((j == 0 || j == 2*i) && i != n-1)
28                     cout << a;
29                 else cout << " ";
30             }
31             cout << endl;
32         }
33         for (int j = 0; j < 2*n-1; ++j)
34             cout << a;
35         cout << endl;
36     }
37     return 0;
38 }
HDU2091
弹指将至而立年,大志未酬发先白。
原文地址:https://www.cnblogs.com/Ddlm2wxm/p/6519347.html