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;

}

相关推荐
oplp2 小时前
第四章 C语言中的基本输入输出(六)
c语言
程序员东岸4 小时前
《数据结构——排序(中)》选择与交换的艺术:从直接选择到堆排序的性能跃迁
数据结构·笔记·算法·leetcode·排序算法
程序员-King.4 小时前
day104—对向双指针—接雨水(LeetCode-42)
算法·贪心算法
神仙别闹4 小时前
基于C++实现(控制台)应用递推法完成经典型算法的应用
开发语言·c++·算法
Ayanami_Reii5 小时前
进阶数据结构应用-一个简单的整数问题2(线段树解法)
数据结构·算法·线段树·延迟标记
listhi5205 小时前
基于改进SET的时频分析MATLAB实现
开发语言·算法·matlab
Keep_Trying_Go6 小时前
基于Zero-Shot的目标计数算法详解(Open-world Text-specified Object Counting)
人工智能·pytorch·python·算法·多模态·目标统计
xl.liu6 小时前
零售行业仓库商品数据标记
算法·零售
confiself6 小时前
通义灵码分析ms-swift框架中CHORD算法实现
开发语言·算法·swift
做怪小疯子6 小时前
LeetCode 热题 100——二叉树——二叉树的层序遍历&将有序数组转换为二叉搜索树
算法·leetcode·职场和发展