空心三角形

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

HDU - 2091 空心三角形 水题,但是有点坑...相关推荐

  1. HDU2091 空心三角形 水题

    空心三角形 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  2. HDU 6168 Numbers 思维 水题

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6168 题目描述: 定义数组b是由数组a每两项的和组成的,现在将数组A, B混在一起给你, 筛出数组A ...

  3. HDU 4393 Throw nails [水题]

    题解写了N多方法,我用的是最水的那种.. 起始区间只有(0 <= Fi <= 500),500秒之后排名必然不会变化了..所以,暴力500秒,然后排个序就行了. 1 #include &l ...

  4. 【HDU - 5455】Fang Fang(水题,有坑)

    题干: Fang Fang says she wants to be remembered.  I promise her. We define the sequence FF of strings. ...

  5. hdu 4823 Energy Conversion(水题)

    Energy Conversion Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  6. HDU 5703 Desert 水题 找规律

    HDU 5703 Desert 水题 找规律 已知有n个单位的水,问有几种方式把这些水喝完,每天至少喝1个单位的水,而且每天喝的水的单位为整数.看上去挺复杂要跑循环,但其实上,列举几种情况之后就会发现 ...

  7. HDU 1033 水题

    题意还真的不好懂,摸索数据就出来了,注意顺时针和逆时针时候的方向变化 /*  * Author:lonelycatcher  * problem:hdu 1033  * Type:水题  */ #in ...

  8. HDU 6264 Super-palindrome(CCPC2017杭州) 水题

    http://acm.hdu.edu.cn/showproblem.php?pid=6264 题目大意:给定字符串TTT,使得该字符串的每个长度为奇数的子串都是回文串,求至少要修改的字符的数量. 思路 ...

  9. 【HDU 1870 --- 愚人节的礼物】栈水题

    [HDU 1870 --- 愚人节的礼物]栈水题 Description 四月一日快到了,Vayko想了个愚人的好办法--送礼物.嘿嘿,不要想的太好,这礼物可没那么简单,Vayko为了愚人,准备了一堆 ...

最新文章

  1. 深度学习100例 | 第34天:如何进行数据增强?
  2. JWT对称加密非对称加密
  3. matlab信道均衡,使用LMS算法做信道均衡时,更换信道传递函数效果很差
  4. cefsharp.wpf离线安装包下载_在vscode里编写c++程序(解决gdb下载失败问题)
  5. 本地开发的 SAP UI5 应用,部署到 ABAP 服务器执行出错的问题分析
  6. Visual C++ MFC/ATL开发-提高篇
  7. python 箭头_Python命名箭头方向
  8. Linux —— shell认识与基础命令
  9. Android开源库集合(控件)
  10. java cpt_1、第十 - WEB开发进阶 - JavaSricpt 正则表达式
  11. Android应用开发环境搭建
  12. Linux的百度云有限速吗,mac(linux)下配置aria2解决百度云限速问题
  13. 干货丨7款易上手C语言编程软件推荐
  14. 最通俗PLC教程—源自Koyo光洋PLC自学总结(2)
  15. python中的Numpy包
  16. 链家网爬取深圳租房信息并存入MySQL
  17. PMEdit一个富文本框可以编辑文本、图片并可以显示GIF动画
  18. <el-tabs>改变样式(去掉下划线及其他样式)
  19. Python 解压rar类型文件
  20. 网站被黑中毒WebShell木马的解决方案

热门文章

  1. python requests模块中返回时间elapsed解析
  2. 如何注册MSN(Microsoft ID)
  3. python def和lambda的应用
  4. Java 启动参数大全
  5. 百度的“框”正在移动
  6. L2-024. 部落-PAT团体程序设计天梯赛GPLT
  7. mysql 将 字符 转换成 数字
  8. 原生js双向数据绑定
  9. 用户模式同步之信号量小解
  10. kuangbin专题一 简单搜索