C:图案打印

打印 上一主题 下一主题

主题 819|帖子 819|积分 2457



弁言

 本篇文章讲了一些常见的图形编程题,并总结了一些规律。
1、打印空心正方形

1.1 代码展示:

  1. #include<stdio.h>
  2. int main()
  3. {
  4.         int a = 0;//边长初始化
  5.         scanf("%d", &a);//输入边长的值
  6.         {
  7.                 int i = 0;
  8.                 for (i = 0; i < a; i++)//控制行数
  9.                 {
  10.                         int j = 0;
  11.                         for (j = 0; j < a; j++)//控制列数
  12.                         {
  13.                                 if (i == 0 || i == a - 1)//判断行数是否打印 *
  14.                                 {
  15.                                         printf("* ");//*后面留一个空格
  16.                                 }
  17.                                 else if (j == 0 || j == a - 1)//判断列数是否打印 *
  18.                                 {
  19.                                     printf("* ");//*后面留一个空格
  20.                             }
  21.                             else
  22.                             {
  23.                                     printf("  ");//这里留两个空格
  24.                             }                               
  25.                         }
  26.                         printf("\n");//换行
  27.                 }                       
  28.         }
  29.         return 0;
  30. }
复制代码
图案展示:

1.2 代码解析:

1.通过scanf函数获得输入的边长值
2.通过两层循环来控制每行每列的输出


  • 外层循环控制行数,当行号为 0(第一行)或 a - 1(最后一行)时,整行打印 *。
  • 内层循环控制列数,当列号为 0(第一列)或 a - 1(最后一列)且当前行不是第一行和最后一行时,打印 * ,其他位置打印两个空格。
3.每行打印完换行。
1.3  分析i == 0 || i == a - 1

 为什么满足这个条件就打印*就可以得到空心正方形?看下图:

这里就用图解释了,如果还有些不明确,可以私我
2、空心三角形

2.1 思路分析


  • 使用两个嵌套的循环,外层循环控制行数,内层循环控制每行的输出。
  • 对于每行,先打印一定命量标空格,使得三角形对齐。
  • 然后判断当前行的位置,如果是第一行、最后一行或者是每行的第一个和最后一个字符位置,打印 * ,否则打印空格。
2.2  代码展示:

  1. #include <stdio.h>
  2. int main() {
  3.     int rows = 0;
  4.     scanf("%d", &rows);//输入行数
  5.     for (int i = 1; i <= rows; i++) {  // 外层循环控制行数
  6.         for (int j = 1; j <= rows - i; j++) {  // 打印每行前面的空格
  7.             printf(" ");
  8.         }
  9.         for (int k = 1; k <= 2 * i - 1; k++) {  // 处理每行的字符输出
  10.             if (k == 1 || k == 2 * i - 1 || i == rows) {  // 第一行、最后一行、每行的首尾位置打印*
  11.                 printf("*");
  12.             } else {  // 中间位置打印空格
  13.                 printf(" ");
  14.             }
  15.         }
  16.         printf("\n");  // 换行
  17.     }
  18.     return 0;
  19. }
复制代码
2.3 代码解析:


  • 定义一个变量rows用来存储行数
  • 内层的第一个 for 循环 for (int j = 1; j <= rows - i; j++) 用于在每行的开头打印得当数量标空格,以使三角形对齐。
  • 内层的第二个 for 循环 for (int k = 1; k <= 2 * i - 1; k++) 处置惩罚每行的字符输出。if (k == 1 || k == 2 * i - 1 || i == rows) 这个条件判断用于确定是否打印 * 。当是每行的第一个字符(k == 1)、最后一个字符(k == 2 * i - 1)或者是最后一行(i == rows)时,打印 * ,否则打印空格。
3、X形图案

3.1代码展示:

  1. #include <stdio.h>
  2. int main()
  3. {
  4.         int size = 0;  // 初始化
  5.     scanf("%d", &size);//输入值
  6.     int i = 0;
  7.         for ( i = 0; i < size; i++)  // 行循环
  8.         {
  9.         int j = 0;
  10.                 for ( j = 0; j < size; j++)// 列循环
  11.                 {  
  12.                         if (i == j || i + j == size - 1)// 判断是否为对角线上的位置
  13.                         {  
  14.                                 printf("*");  // 打印 '*'
  15.                         }
  16.                         else
  17.                         {
  18.                                 printf(" ");  // 否则打印空格
  19.                         }
  20.                 }
  21.                 printf("\n");  // 换行
  22.         }
  23.         return 0;
  24. }
复制代码
 图案展示:

3.2 代码解析:

1.先定义一个变量size来表现图案的大小;
2.使用两个嵌套的for循环,外层控制行数,内层控制列数;
3.你可以将图案看作在一张表格上,对于每个位置( i , j ),通过条件判断 i == j 表现主对角线(从左上角到右下角)上的位置,
 i + j == size - 1表现副对角线(从右上角到左下角)上的位置。
4.如果当前位置在对角线上,则打印 *,否则打印空格。
5.每行打印完后,记得换行。
3.3 i == j || i + j == size - 1解释

假设我们有一个 size*size 的二维矩阵(比方 5×5)。
对于主对角线(从左上角到右下角),行索引 i 和列索引 j 是相等的,即 i == j 。(索引即下标);
比方,在 5*5 的矩阵中,主对角线上的点为 (0, 0)、(1, 1)、(2, 2)、(3, 3)、(4, 4),都满足 i == j 。
对于副对角线(从右上角到左下角),行索引 i 与列索引 j 的和等于矩阵的边长减 1,即 i + j == size - 1 。
比方,在 5*5 的矩阵中,副对角线上的点为 (0, 4)、(1, 3)、(2, 2)、(3, 1)、(4, 0),都满足 i + j == 4 (由于 5 - 1 = 4)。
以是,当满足 (i == j || i + j == size - 1) 这个条件时,就可以确定是在这两条对角线上。
3.4 留意事项:

   printf("\n");  //换行不要写到内循环内里去了,否则会出现下面这种情况
  



4.沙漏

4.1  代码展示:

  1. #include <stdio.h>
  2. int main() {
  3.     int a = 0;
  4.     printf("请输入沙漏的行数(奇数): ");
  5.     scanf("%d", &a);//输入行数
  6.     for (int i = 1; i <= a; i++) {  //外层循环控制上半部分沙漏的行数,从第 1 行到第 a 行
  7.         for (int j = 1; j < i; j++) { //内层循环打印每行开头的空格,空格数量逐行递增
  8.             printf(" ");
  9.         }
  10.         for (int k = 1; k <= 2 * (a - i + 1) - 1; k++) {
  11.             printf("*");//内层循环打印星号,星号数量逐行递减
  12.         }
  13.         printf("\n");//换行
  14.     }
  15.     for (int i = a - 1; i >= 1; i--) { // 外层循环控制下半部分沙漏的行数,从倒数第 2 行到第 1 行
  16.         for (int j = 1; j < i; j++) { // 内层循环打印每行开头的空格,空格数量逐行递减
  17.             printf(" ");
  18.         }
  19.         for (int k = 1; k <= 2 * (a - i + 1) - 1; k++) {
  20.             printf("*");// 内层循环打印星号,星号数量逐行递增
  21.         }
  22.         printf("\n");
  23.     }
  24.     return 0;
  25. }
复制代码
图案演示:

4.2 分析(结合解释)

对于上半部分:


  • 随着 i 的增加,每行前面的空格数量也增加,由于 j < i 。
  • 同时,星号的数量通过 2 * (a - i + 1) - 1 计算得到,随着 i 的增加而减少。
对于下半部分:(对称)


  • 随着 的减小,每行前面的空格数量减少。
  • 星号的数量通过相同的公式计算,随着 i 的减小而增加,从而形成与上半部分对称的沙漏形状。
5、一些规律

1 使用嵌套的循环结构

外层循环通常控制图形的行数。内层循环控制每行的输出内容,比如空格数量、特定字符的数量等。
2 使用对称性

对于对称的图形,常常可以使用上半部分和下半部分的对称关系,通过修改循环的条件和范围来减少重复的代码。
3 留意边界条件

比方对于三角形、矩形等图形,要正确处置惩罚第一行、最后一行、第一列和最后一列的输出,以确保图形的形状完备和准确。
4 使用控制语句

如 if-else 语句来区分不同的行或列的输出模式。
5 以行列的头脑为底子

学会逐行逐列构造图形。

结语: 

图形化编程标题对于帮助我们熟悉循环和控制结构的使用非常有帮助。通过这些标题,我们可以更加深入地明确循环和控制结构的工作原理,并且可以或许在实践中更好地应用它们。
来日诰日开始更新C语言的知识模块!!!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

数据人与超自然意识

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表