C语言| 输出*三角形

分析:

① 输入三角形主要分为两部分,

即输出空格和输出星号,要将它们分开,不用考虑空格数和星号个数之间的关系。

② 从每行输出的空格个数来看,若总共输出n行,则第i行首先要输出n - i个空格,然后再输出星号。

③ 从每行输出的星号个数来看,每行输出星号的个数是一个首项为1、公差为2的等差数列,

等差数列的公式为:an=a1+(n -1) d即第i行要输入的星号个数为1+(i -1)×2=2×i -1。

④ 编程时我们只需要考虑星号和星号左边的空格即可。星号右边的空格不用考虑。

当遇到N的情况,不知道如何下手,可以先给N赋一个值,从具体的事物开始分析,最后会得到抽象的结果。

【程序代码】

/*

#include <stdio.h>

int main(void)

{

//固定行数,5行

for(int j=0; j<5; j++)

{

//左边的空格

for(int z=0; z<5-j; z++)

{

printf(" ");

}

//右边的星星

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

{

printf("*");

}

printf("\n");

//对每一行,将左边的空格加上星星,就是图形

}

return 0;

}

*/

#include <stdio.h>

int main(void)

{

int n=0; //存储行数

int i, j; //行循环变量i,空格和星号循环变量

printf("请输入行数:");

scanf("%d", &n);

//行数由用户输入的n决定

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

{

//左边的空格

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

{

printf(" ");

}

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

{

printf("*");

}

printf("\n");

}

return 0;

}

相关推荐
IronMurphy2 小时前
【算法三十九】994. 腐烂的橘子
算法
Tomhex3 小时前
C语言内存安全防护指南
c语言
Ares-Wang3 小时前
算法》》旅行商问题 TSP、7座桥问题 哈密顿回路 深度优先 和 宽度优先
算法·深度优先·宽度优先
Liqiuyue3 小时前
Transformer:现代AI革命背后的核心模型
人工智能·算法·机器学习
WolfGang0073213 小时前
代码随想录算法训练营 Day34 | 动态规划 part07
算法·动态规划
Kk.08024 小时前
Linux(十一)fork实例练习、文件操作示例及相关面试题目分享
linux·运维·算法
潇冉沐晴5 小时前
2026CCCC第三次模拟赛 部分题解
算法
230万光年的思念5 小时前
zerotier连不上的问题
c语言
WolfGang0073215 小时前
代码随想录算法训练营 Day32 | 动态规划 part05
算法·动态规划