请用C语言编程:输入一个正整数,各输出n行的正(倒)三角形宝塔图案?

请高手们帮忙指点下....谢谢

正三角形:第几行就是几颗星

倒三角形:第几行就是n-几颗星

正宝塔:第几行就是几*2-1颗星,前面加n-几个空格

用i循环控制行数,循环中用i值计算具体输出几个空格和星号

#include<stdio.h>
#define KG (n-i)
#define XH (i*2+1)
void main() { int i,j,n;
  scanf("%d",&n);
  for ( i=0;i<n;i++ ) {
    for ( j=0;j<KG;j++ ) printf(" ");
    for ( j=0;j<XH;j++ ) printf("*");
    printf("\n");
  }
}

倒宝塔,修改程序中以下两句即可

#define KG (i)
#define XH ((n-i-1)*2+1)

温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-01-16

倒三角只需要两个循环就可以实现:

#include<stdio.h>
int main()
{
int n;
while(scanf("%d",&n)!=EOF){
for (int i = n; i >= 1; i--)
{for(int j=1;j<=2*i-1;j++)
printf("#");
printf("\n");
}}
return 0;
}

同样道理,正三角就是把循环那部分翻一下就好了,留给你思考一下哈。不会还可以追问。


第2个回答  2018-03-30

#include <stdio.h>



main()


{


int i,j,k;


int n;


scanf("%d",&n);


//正三角 


for(i=0;i<n;i++)


{


for(j=0;j<n-i;j++)


printf(" ");


for(k=0;k<=i;k++)


printf(" *");


printf("\n");


}



//倒三角


for(i=0;i<n;i++)


{


for(j=0;j<=i;j++)


printf(" ");


for(k=0;k<n-i;k++)


printf(" *");


printf("\n");



}

int i,j; 


int n; 


scanf("%d",&n); 


for (i=1;i<=n;i++) 



for (j=1;j<=n-i;j++) 


printf(" "); 


for (j=1;j<=2*i-1;j++) 


printf("*"); //这里的"*"可以替换成任意字符 


printf("\n"); 


}

//下面是倒三角 


for (i=n;i>=1;i--) 



for (j=1;j<=n-i;j++) 


printf(" "); 


for (j=1;j<=2*i-1;j++) 


printf("*"); //这里的"*"可以替换成任意字符 


printf("\n"); 


}

本回答被网友采纳
第3个回答  2013-07-27
int i,j;
int n;
scanf("%d",&n);
for (i=1;i<=n;i++)
{
for (j=1;j<=n-i;j++)
printf(" ");
for (j=1;j<=2*i-1;j++)
printf("*"); //这里的"*"可以替换成任意字符
printf("\n");
}

//下面是倒三角
for (i=n;i>=1;i--)
{
for (j=1;j<=n-i;j++)
printf(" ");
for (j=1;j<=2*i-1;j++)
printf("*"); //这里的"*"可以替换成任意字符
printf("\n");
}
第4个回答  2017-10-18
#include <stdio.h>
#include <stdlib.h>
int main()
{
int a,b,c,d,e;
a=1;
scanf("%d",&c);
while(a<=c)
{
b=1;
while(b<=c-a)
{
printf(" ");
b=b+1;
}
e=1;
d=2*a-1;
while(e<=d)
{
printf("*");
e=e+1;
}

printf("\n");
a=a+1;
}
system("pause");
return 0;
}
新手自己琢磨的
相似回答