空心三角形

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

弹指将至而立年,大志未酬发先白。

最新文章

  1. 百钱买百鸡问题 php版本
  2. 我心中的核心组件(可插拔的AOP)~分布式文件上传组件~基于FastDFS
  3. HDU 5492(DP) Find a path
  4. Visual Studio跨平台开发实战(1) - Hello Xamarin!
  5. c语言scanf详解
  6. 一道js题(引用类型、基本类型、包装对象、函数赋值)
  7. 修改maven本地仓库的位置
  8. NPM(Node.js) 使用介绍
  9. 【easy】784. Letter Case Permutation
  10. 我的自定义框架 || 基于Spring Boot || 第一步
  11. WGS84投影的WKID说明
  12. iOS程序的执行顺序 和 UIViewController的生命周期
  13. python 入门基础4 --数据类型及内置方法
  14. Serializable 介绍
  15. libev4.15学习
  16. System.out.println()详解 和 HttpServletRequest 和 XMLHttpRequest
  17. frm和ibd恢复sql文件的操作
  18. BZOJ3238: [Ahoi2013]差异(后缀自动机)
  19. echarts3.0 本期累计堆叠
  20. inode备忘

热门文章

  1. POJ_2828 Buy Tickets 【线段树】
  2. Bi-shoe and Phi-shoe LightOJ - 1370(数论+素数筛)
  3. 仿String()构造器函数 【总结】
  4. 攻防世界 reverse elrond32
  5. matplotlib常规使用方法
  6. [LeetCode]1. 两数之和(难度:简单)
  7. Java高并发测试框架JCStress
  8. Dynamics CRM Report安装出错三
  9. UnitFourSummary
  10. PAT A1025 考生排名问题