杭电2091

题目来源 :http://acm.hdu.edu.cn/showproblem.php?pid=2091

空心三角形

Problem Description

把一个字符三角形掏空,就能节省材料成本,减轻重量,但关键是为了追求另一种视觉效果。在设计的过程中,需要给出各种花纹的材料和大小尺寸的三角形样板,通过电脑临时做出来,以便看看效果。


Input

每行包含一个字符和一个整数n(0<n<41),不同的字符表示不同的花纹,整数n表示等腰三角形的高。显然其底边长为2n-1。如果遇到@字符,则表示所做出来的样板三角形已经够了。


Output

每个样板三角形之间应空上一行,三角形的中间为空。显然行末没有多余的空格。


Sample Input

X 2

A 7

@


Sample Output


遇到的问题 :通过题目的意思要我们获取输入的字符和一个数N来画出一个三角形遇到@结束程序

解决的思路 :先通过char来获取字符然后获取N,输入一个字符a和高的长度n,则底边的长为2n-1。需要注意的是,换行是在第二组数据输入完字符和高的长度之后在换行。 而且中间空格的数目随着i的增加而增加,还有换行不能使用printf(“\n”),否则不会换行

#include<stdio.h>

int main()

{

int i,j,k,n,len=0;//i。j,k都是用来控制空格的输出,len是用来控制换行的//

char a;//定义一个字符//

while(scanf("%c",&a),a!='@')//@表示要做的三角形已经做好了//

{

scanf("%d",&n);

if(len>0)  putchar('\n');//控制输入字符a和高度n后就换行//

if(n==1) printf("%c\n",a);

else

{

for(i=1;i<=n-1;i++)//控制前n-1行//

{

for(j=1;j<n+i;j++)//控制各行的字符和空格的输出//

{

if(j==(n-i+1)||j==(n+i-1))//由事例可以的出的规律,两腰的字符是随着i的变换而改变位置的//

printf("%c",a);

else

printf(" ");

}

putchar('\n');//换行到最后一行//

}

for(k=1;k<=2*n-1;k++)

{

printf("%c",a);//底边是一整行输出字符的//

}

putchar('\n');//最后要换行//

}

len++;//用来控制输入字符和高度后才换行的//

getchar();

}

return 0;

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容