本文主要是介绍C语言之随心所欲打印三角形,金字塔,菱形(倒金字塔),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
个人主页(找往期文章包括但不限于本期文章中不懂的知识点): 我要学编程(ಥ_ಥ)-CSDN博客
目录
三角形
金字塔
倒金字塔
菱形
三角形
题目:根据输入的行数打印对应的三角形。(用 * 号打印)
#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;
}
金字塔
题目:根据输入的行数打印对应的金字塔。(用 * 号和空格打印)
#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。当然这个题的规律不止这一种,我就不列举了。
倒金字塔
题目:根据输入的行数打印对应的菱形。(用 * 号和空格打印)
#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 有关系,再通过多组推敲,得出是这个规律。
菱形
题目:根据输入的行数打印对应的菱形。(用 * 号和空格打印)
#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语言之随心所欲打印三角形,金字塔,菱形(倒金字塔)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!