C语言 —— 图形打印

题目1:

思路:
如果我们要打印一个实心正方形,其实就是一个二维数组,i控制行,j控制列,行列不需要控制,arrij直接打印星号即可。
对于空心正方形,我们只需要控制行和列的条件,当i== 0或i<n-1,j==0或j<n-1条件成立时,我们才打印星号,其他地方打印空格即可。

代码实现如下:

c 复制代码
#include <stdio.h>

int main()
{
	int arr[20][20] = { 0 };
	int n = 0;
	while (scanf("%d", &n) != EOF)
	{
		for (int i = 0; i < n; i++)
		{
			for (int j = 0; j < n; j++)
			{
				//1.打印星号
				if ((i == 0) || (i == n - 1) || (j == 0) || (j == n - 1))
				{
					printf("* ");
				}
				//2.打印空格
				else
				{
					printf("  ");
				}

			}
			printf("\n");
		}
	}
	return 0;
}

题目2:

思路:

通过观察我们发现,当i == j时,打印主对角线的星号,当i + j ==n-1时,打印次对角线的星号,其他地方打印空格即可。

代码实现如下:

c 复制代码
#include <stdio.h>

int main()
{
	int arr[20][20] = { 0 };
	int n = 0;
	while (scanf("%d", &n) != EOF)
	{
		for (int i = 0; i < n; i++)
		{
			for (int j = 0; j < n; j++)
			{
				//1.打印星号
				if ((i == j) || (i + j) == n-1)
				{
					printf("*");
				}
				//2.打印空格
				else
				{
					printf(" ");
				}
			}
			printf("\n");
		}
	}
	return 0;
}

题目3:

思路:我们分为上半部分和下半部分的打印:

c 复制代码
#include <stdio.h>

int main()
{
	int line = 0;
	scanf("%d", &line);
	//打印上半部分
	for (int i = 0; i < line; i++)
	{
		//1.打印空格
		for (int j = 0; j < line - 1 - i; j++)
		{
			printf(" ");
		}
		//2.打印星号
		for (int j = 0; j < 2 * i + 1; j++)
		{
			printf("*");
		}
		printf("\n");
	}
	//打印下半部分
	for (int i = 0; i < line - 1; i++)
	{
		//1.打印空格
		for (int j = 0; j < i + 1; j++)
		{
			printf(" ");
		}
		//2.打印星号
		for (int j = 0; j < (line - 1 - i) * 2 - 1; j++)
		{
			printf("*");
		}
		printf("\n");
	}

	return 0;
}
相关推荐
比昨天多敲两行2 分钟前
linux 线程概念与控制
java·开发语言·jvm
huaweichenai11 分钟前
php 根据每个类型的抽签范围实现抽签功能
开发语言·php
codeejun2 小时前
每日一Go-73、云原生成本优化 —— 资源限制 & 指标驱动扩容
开发语言·云原生·golang
就叫_这个吧2 小时前
Java注解、元注解、自定义注解定义及应用
java·开发语言·注解
Sam_Deep_Thinking2 小时前
聊聊Java中的of
java·开发语言·架构
小小de风呀5 小时前
de风——【从零开始学C++】(十一):list的基本使用和模拟实现
开发语言·c++·list
三行数学5 小时前
Matlab之父克利夫·莫勒尔逝世
开发语言·matlab
陌路205 小时前
C++高级进阶--夯实进阶基础(1)
开发语言·c++
梦想三三6 小时前
【PYthon词频统计与文本向量化】苏宁易购评论分析实战
开发语言·python
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第93题】【Mysql篇】第23题:从查找速度来看,聚集索引和非聚集索引哪个更快?
java·开发语言·数据库·mysql·面试