- 题目要求
- 一、实现代码
- 结果图
- 二、代码步骤
- 1、画图分析
- 2、实现图一分析
- 2、实现图二分析
- 三、思考怎么打印倒金字塔
题目要求
1、打印金字塔
2、键盘输入金字塔的层数
一、实现代码
#include结果图 二、代码步骤 1、画图分析int main() { int j = 1, i = 1, count = 3;//1、1默认层数为3 int k = 0,empty = 0; //2.1、初始化空格 scanf("%d",&count);//3、键盘输入 for (j = 1; j <= count; j++)//金字塔层数 { for (empty = 0; empty < count - j; empty++)//2.2打印空格 { printf(" "); } k = 2 * j - 1;//1.3因为for循环的表达式1会把i初始化所以用k代表结束条件 for (i = 1; i <= k; i++)//1.2每层金字塔的个数 { printf("*"); } printf("n");//换行 } }
图1
2、实现图一分析代码如下:
#includeint main() { int j = 1, i = 1, count = 3;//默认层数为3 int k = 0; for (j = 1; j <= count; j++)//金字塔层数 { k = 2 * j - 1;//因为for循环的表达式1会把i初始化所以用k代表结束条件 for (i = 1; i <= k; i++)//每层金字塔的个数 { printf("*"); } printf("n");//换行 } }
结果(因为没有加入空格):
代码如下:
#includeint main() { int j = 1, i = 1, count = 3;//1、1默认层数为3 int k = 0,empty = 0; //2.1、初始化空格 for (j = 1; j <= count; j++)//金字塔层数 { for (empty = 0; empty < count - j; empty++)//2.2打印空格 { printf(" "); } k = 2 * j - 1;//1.3因为for循环的表达式1会把i初始化所以用k代表结束条件 for (i = 1; i <= k; i++)//1.2每层金字塔的个数 { printf("*"); } printf("n");//换行 } }
结果
最终结果只需要把count改为键盘输入就行了