解题思路:
观察图形,拆分成每一行来看。第一行和最后一行是比较特殊的(只有一个*),其余部分每行都有两个*,然而这一部分又可以分为两个部分,正梯形部分和倒梯形部分
(需要注意的是导梯形部分少了一行,因为菱形的行数为奇数,除去顶部和底部,还是一个奇数行,无法做到平分,故而我将这一行正梯形部分)。
代码:
#include <stdio.h>
int main(){
int n,i,m=1; //i记录行数,m控制两*之间空格的个数
printf("请输入边长n(大于1):");
scanf("%d",&n);
printf("%*s*",n-1,""); //输出第一行*(第一个*表示占位符,用来输出n-1个"(空格)"
printf("\n");
//打印正金字塔
for(i=2;i<=n;i++,m+=2){
printf("%*s*%*s*",n-i,"",m,""); //空格,*号个数控制部分
printf("\n");
}
//打印倒金字塔
for(i=n,m=m-4;i>2;i--,m-=2){
printf("%*s*%*s*",n-i+1,"",m,"");
printf("\n");
}
printf("%*s*",n-1,"",n,"" ); //输出最后一行*
return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/82684.html