C语言之随心所欲打印三角形,金字塔,菱形(倒金字塔)

个人主页(找往期文章包括但不限于本期文章中不懂的知识点): 我要学编程(ಥ_ಥ)-CSDN博客

目录

三角形

金字塔

倒金字塔

菱形


三角形

题目:根据输入的行数打印对应的三角形。(用 * 号打印)

cs 复制代码
#include <stdio.h>
int main()
{
	int row = 0;
	scanf("%d", &row);
	int i = 0;
	for (i = 0; i < row; i++)//打印行
	{
		int j = 0;
		for (j = 0; j < 2 * i + 1; j++)//打印列
		{
			printf("*");
		}
		printf("\n");//换行
	}
	return 0;
}

金字塔

题目:根据输入的行数打印对应的金字塔。(用 * 号和空格打印)

cs 复制代码
#include <stdio.h>
int main()
{
	int row = 0;
	scanf("%d", &row);
	int i = 0;
	for (i = 0; i < row; i++)//行
	{
		//金字塔除了星号(*),还有空格。每一行只有星号要全部打印,空格只要打印一半(左边的)
		int j = 0;
		for (j = 0; j < row - i; j++)
		{
			printf(" ");
		}
		for (j = 0; j < 2 * i + 1; j++)
		{
			printf("*");
		}
		printf("\n");
	}
	return 0;
}

至于右边,我们只需要打印*,不需要打印空格。而左边就都需要打印 ,我们先来找一下规律。(这种打印图形的都是有规律的) 空格是5--->1的逐级递减(只看左边),而*是1,3--->9的奇数跳跃增加(全部一起看)。空格 = 行数 - i ,* = 2i + 1。当然这个题的规律不止这一种,我就不列举了。

倒金字塔

题目:根据输入的行数打印对应的菱形。(用 * 号和空格打印)

cs 复制代码
#include <stdio.h>
int main()
{
	int row = 0;
	scanf("%d", &row);
	int i = 0;
	for (i = 0; i < row; i++)
	{
		int j = 0;
		for (j = 0; j < i + 1; j++)
		{
			printf(" ");
		}
		for (j = 0; j < 2 * (row - i) - 1; j++)
		{
			printf("*");
		}
		printf("\n");
	}
	return 0;
}

空格 = i + 1,因为是逐级变化,肯定是与 i 有关(第一个空格数是1) 。* = 2(row- i)- 1。* 是跳跃变化,就肯定和2 * i 有关系,再通过多组推敲,得出是这个规律。

菱形

题目:根据输入的行数打印对应的菱形。(用 * 号和空格打印)

cs 复制代码
#include <stdio.h>
int main()
{
	int row = 0;
	scanf("%d", &row);
	int uppart = row / 2 + row % 2;
	int lopart = row - uppart;
	int i = 0;
	//打印上半部分
	for (i = 0; i < uppart; i++)
	{
		int j = 0;
		for (j = 0; j < uppart - i; j++)
		{
			printf(" ");
		}
		for (j = 0; j < 2 * i + 1; j++)
		{
			printf("*");
		}
		printf("\n");
	}
	//打印下半部分//就是倒金字塔
	for (i = 0; i < lopart; i++)
	{
		int j = 0;
		for (j = 0; j < i + 2; j++)
		{
			printf(" ");
		}
		for (j = 0; j < 2 * (lopart - i) - 1; j++)
		{
			printf("*");
		}
		printf("\n");
	}
	return 0;
}

上半部分的打印,其实就是打印那个金字塔。而下半部分就是倒着的金字塔。

空格 = i + 2,因为是逐级变化,肯定是与 i 有关 。* = 2(lopart - i)- 1。* 是跳跃变化,就肯定和2 * i 有关系,再通过多组推敲,得出是这个规律。

总结:这种图形的打印是有规律的。这个规律得通过多组数据来推敲,演化,来得出。以上的所有图形的空格数都是以输入的数作为参照的。(就是输入的行数的那一列,不计数空格数)

相关推荐
李白同学几秒前
【C语言】结构体内存对齐问题
c语言·开发语言
楼台的春风1 小时前
【MCU驱动开发概述】
c语言·驱动开发·单片机·嵌入式硬件·mcu·自动驾驶·嵌入式
大数据追光猿1 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!2 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉2 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生2 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴2 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing2 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode
qy发大财2 小时前
加油站(力扣134)
算法·leetcode·职场和发展
王老师青少年编程2 小时前
【GESP C++八级考试考点详细解读】
数据结构·c++·算法·gesp·csp·信奥赛