杭电2091(空心三角形)

空心三角形

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

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
#include<iostream>
using namespace std;
int main()
{
    int n,l=1;
    char ch;
    while(1)
    {
        cin>>ch;
        if(ch==‘@‘)
        break;
        cin>>n;
        if(l!=1)
        cout<<endl;
        for(int i=0;i<n-1;i++)
        {
            for(int j=0;j<n-1-i;j++)
            cout<<‘ ‘;  cout<<ch;
            for(int j=0;j<2*i-1;j++)
            cout<<‘ ‘;  if(i!=0) cout<<ch;
            cout<<endl;
        }
        for(int k=2*n-1;k>0;k--)
        cout<<ch; cout<<endl; l++;
    }
    return 0;
}
时间: 2024-10-29 19:06:52

杭电2091(空心三角形)的相关文章

杭电2091 空心三角形

题目链接: 解题思路:1—注意输出格式,PE了好多次,具体格式分析见下,从discuss·里面粘贴过来的http://acm.hdu.edu.cn/discuss/problem/post/reply.php?postid=16852&messageid=1&deep=0 反思----边界值一定要多考虑,比如这题只有一行的情况 #include<stdio.h> int main() { char c; int n,t=1; while(scanf("%c %d&qu

HDU 2091 空心三角形 --- 水题

/* HDU 2091 空心三角形 --- 水题 */ #include <cstdio> int main() { int kase = 0; char ch; int h, t; //h表示高 while (scanf("%c", &ch) == 1 && ch != '@'){ scanf("%d", &h); if (kase++){ printf("\n"); } getchar(); if

空心三角形(杭电2091)

/*空心三角形 Problem Description 把一个字符三角形掏空.就能节省材料成本.减轻重量,但关键是为了追求还有一种视觉效果.在设计的过程中.须要给出各种花纹的材料和大小尺寸的三角形样板.通过电脑暂时做出来.以便看看效果. Input 每行包括一个字符和一个整数n(0<n<41),不同的字符表示不同的花纹.整数n表示等腰三角形的高.显然其底边长为2n-1. 假设遇到@字符.则表示所做出来的样板三角形已经够了. Output 每一个样板三角形之间应空上一行,三角形的中间为空. 显然

hdoj 2091 空心三角形

空心三角形 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 29368    Accepted Submission(s): 8074 Problem Description 把一个字符三角形掏空,就能节省材料成本,减轻重量,但关键是为了追求另一种视觉效果.在设计的过程中,需要给出各种花纹的材料和大小尺寸的三角形样板,通过电脑临时做出来,

杭电ACM2091--空心三角形

http://acm.hdu.edu.cn/showproblem.php?pid=2091 scanf 和 printf的输入输出功能并不强大.有时候我们需要清空输入输出流,所以一定切记getchar()的使用. <span style="font-size:18px;">#include <stdio.h> int main() { char a; int i,j,k=0,n; scanf("%c",&a); while (a!=

杭电OJ -- 2039 三角形

这道题只有一个梗,那就是定义边的时候要定义为float或者double类型,定义为int一定错. #include <iostream> using namespace std; int main() { int m; double n1, n2, n3; cin >> m; while (m--) { cin >> n1 >> n2 >> n3; //输入三条边的长度 if ((n1 + n2 > n3) && (n1 +

hdu 2091 空心三角形

这题还是比较坑的首先要注意两点: 1.行末没有多余的空格; 2.就是当n==1的时候单独判断; #include <iostream> using namespace std; int main() { char ch; int n,flag=0; while(cin>>ch) { if(ch=='@') break; cin>>n; if(flag) cout<<endl; flag=1; if(n==1) { cout<<ch<<

杭电2091

1 #include<stdio.h> 2 3 int main() 4 { 5 int n,i,j,t=0; 6 char c; 7 while(scanf("%c",&c)!=EOF&&c!='@') 8 { 9 scanf("%d",&n); 10 getchar(); 11 if(t++) 12 printf("\n"); 13 for(i=0; i<n; ++i) 14 { 15 for

杭电ACM分类

杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze 广度搜索1006 Redraiment猜想 数论:容斥定理1007 童年生活二三事 递推题1008 University 简单hash1009 目标柏林 简单模拟题1010 Rails 模拟题(堆栈)1011 Box of Bricks 简单题1012 IMMEDIATE DECODABILITY