前言
一.打印菱形
这样的图形该怎么打印呢?这个菱形分为上三角和下三角,假设我们呢要打印的行数为line
从上图可以可以知道上三角,从上到下实心点的个数为 1 3 5
这个点的规律跟打印的行数有什么规律呢,细心观察可以发现 y = 2*line-1 (1<=line<=3)
那么上三角右侧的空格和实心点的有什么规律呢,留心观察,我们发现上三角右侧的空格分别为 2 1 0,这个数字是不是跟行数有什么特别的关系呢
第一行空格数:3-1=2
第二行空格数:3-2 =1
第三行空格数:3-3=0
由此可知空格数=line-遍历的行数
到这里我们线先写代码打印上三角
1.打印上三角
#include <iostream>
using namespace std;
void print();
int main() {
print();
system("pause");
return 0;
}
void print() {
int line = 3;
for (int i = 1;i<=line;i++) {
//打印空格
for (int j =1; j<=line-i;j++) {
cout << " ";
}
//打印实心点
for (int k = 1; k<= 2*i-1;k++) {
cout << '*';
}
//打印完一行,换行
cout << endl;
}
}
2.打印下三角
首先分析下三角的规律:
下三角和上三角共底边,因此我们只需要打印两次,即循环line-1次
实心三角分析:
第一次打印2个
第二次打印 1个
实心个数2*(line-i-1)-1 (i的取值范围为 0 1)
左侧空格数分别为 1 2 空格数=line+1 (遍历下标从0开始)
代码:
#include <iostream>
using namespace std;
void print();
int main() {
print();
system("pause");
return 0;
}
void print() {
int line = 3;
for (int i = 1;i<=line;i++) {
//打印空格
for (int j =1; j<=line-i;j++) {
cout << " ";
}
//打印实心点
for (int k = 1; k<= 2*i-1;k++) {
cout << '*';
}
//打印完一行,换行
cout << endl;
}
//打印下三角
for (int i=0;i<line-1;i++) {
//打印空格
for (int j=0;j<i+1;j++) {
cout << " ";
}
//打印实心点
for (int k = 0;k<2*(line-i-1)-1;k++) {
cout << "*";
}
cout << endl;
}
}