这样的图形该怎么打印呢?这个菱形分为上三角和下三角,假设我们呢要打印的行数为line
从上图可以可以知道上三角,从上到下实心点的个数为 1 3 5
这个点的规律跟打印的行数有什么规律呢,细心观察可以发现 y = 2*line-1 (1<=line<=3)
那么上三角右侧的空格和实心点的有什么规律呢,留心观察,我们发现上三角右侧的空格分别为 2 1 0,这个数字是不是跟行数有什么特别的关系呢
第一行空格数:3-1=2
第二行空格数:3-2 =1
第三行空格数:3-3=0
由此可知空格数=line-遍历的行数
到这里我们线先写代码打印上三角
#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; } }
首先分析下三角的规律:
下三角和上三角共底边,因此我们只需要打印两次,即循环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; } }