C 练习实例23

**题目:**打印出如下图案(菱形)。

*

***

*****

*******

*****

***

*


题目分析:

先打印前4行,因为是递增关系。

第0行:打印3个空格,1个*

第1行:打印2个空格,3个*

第2行:打印1个空格,5个*

第3行:打印0个空格,7个*

不难发现规律:(设行序列为 i )

空格数是行序列以3的补码,

第 i 行打印的空格数 =3 - i

第 i 行打印 * 的个数 = 2 * i + 1

后打印后三行,因为是递减规律。(行序号自己定,就是个循环标号,怎么方便怎么来,无所谓)

i = 2时,第 2 行 空格数 = 1,* 数 = 5

i = 1时,第 1 行 空格数 = 2,* 数 = 3

i = 0时,第 0 行 空格数 = 3,* 数 = 1

**规律:**空格数 = 3 - i , * 数 = 2 * i + 1

代码:

cpp 复制代码
#include <stdio.h>
int main()
{
	int i,j,k;
	//打印前4行
	for(i=0;i<4;i++){	//最外层循环控制行,打印换行符
		for(j=0;j<3-i;j++){	//打印空格,i(行序号)=0时,循环打印3次空格
			printf(" ");			//  i(行序号)=1时,循环打印2次空格
		}							//  i(行序号)=2时,循环打印1次空格
		for(k=0;k<2*i+1;k++){//打印 * ,i(行序号)=0时,循环打印1次 * 
			printf("*");	// 	        i(行序号)=1时,循环打印3次 * 
		}					//    	    i(行序号)=2时,循环打印5次 * 
		printf("\n");
	}
	//打印行3行
	for(i=2;i>=0;i--){
		for(j=0;j<3-i;j++){	//打印空格,i(行序号)=2时,循环打印1次空格
			printf(" ");			//  i(行序号)=1时,循环打印2次空格
		}							//  i(行序号)=0时,循环打印3次空格
		for(k=0;k<2*i+1;k++){//打印 * ,i(行序号)=2时,循环打印5次 * 
			printf("*");	//    	    i(行序号)=1时,循环打印3次 * 
		}					//    	    i(行序号)=2时,循环打印5次 * 
		printf("\n");
	}
	return 0;
}

结果:

bash 复制代码
   *
  ***
 *****
*******
 *****
  ***
   *

--------------------------------
Process exited after 0.2859 seconds with return value 0
请按任意键继续. . .
相关推荐
序属秋秋秋2 小时前
算法基础_基础算法【位运算 + 离散化 + 区间合并】
c语言·c++·学习·算法·蓝桥杯
ん贤5 小时前
2024第十五届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组
c语言·数据结构·c++·经验分享·笔记·算法·蓝桥杯
口嗨农民工6 小时前
mksquashfs文件系统的使用
c语言
1zero106 小时前
[C语言笔记]09、指针
c语言·开发语言·笔记
似水এ᭄往昔1 天前
【C语言】文件操作
c语言·开发语言
蒙奇D索大1 天前
【数据结构】第六章启航:图论入门——从零掌握有向图、无向图与简单图
c语言·数据结构·考研·改行学it
烂蜻蜓1 天前
C 语言中的递归:概念、应用与实例解析
c语言·数据结构·算法
javaisC1 天前
c语言数据结构--------拓扑排序和逆拓扑排序(Kahn算法和DFS算法实现)
c语言·算法·深度优先
小郝 小郝1 天前
【C语言】strstr查找字符串函数
c语言·开发语言
Dovis(誓平步青云)1 天前
【数据结构】排序算法(中篇)·处理大数据的精妙
c语言·数据结构·算法·排序算法·学习方法