前言
使用C语言打印图形,金字塔(等腰三角形),菱形(用两个等腰三角形上下拼在一起),V形(有正V和倒V)。
所编写的代码是可以改变行数的,在运行时,输入行数,就可以打印出来!当然也可以直接用printf打印出来,但是行数就不可以更改了。这里是前者啊。
一、打印金字塔(等腰三角形)
1.图案
我们要打印出来如图所示的图案。
这里我们可以找到规律:第一行是1个,第二行是3个,以此类推1,3,5,7,9.........?(自己想一想怎么得到这些数)。
?然后我们可以发现图案前面空格的规律:第一行6个,第二行5个,以此类推6,5,4,3,2,1,0(再想一想这要怎么得到)。
?
2.代码
#include<stdio.h>
int main()
{
int i = 0;
int j = 0;
int n = 0;
int s = 0;
printf("请输入行数:");
scanf("%d", &n);
for (i = 0; i < n; i++)//行数
{
for (j = 1; j < n - i; j++)//每一行之前的空格
{
printf(" ");
}
for (s = 0; s < i * 2 + 1; s++)//打印星号
{
printf("*");
}
printf("\n");
}
}
?前面第一步先建立变量,然后要确定行数(n)这里使用scanf()来确定。有了行数之后就要打印每一行之前的空格,是依次递减的,这里用(n-i)就可以得到6.5.4.3.2.1.0。
空格好了之后就是打印星号部分,根据1,3,5,7,9我们可以找到规律,每一个数都是(i*2+1)得到的,例如:i=0,那么i*2+1=1。
最后每打印一行,最后都进行换行。
?
二、打印菱形(两个三角形拼在一起)
1.图案
我们要打印出来下图的菱形。
首先还是要找一下规律,这个菱形是由一个三角形和一个倒三角拼成的图案。在上面我们已经知道了三角形如何打印,那么倒着的三角形怎么解决呢?(自己认真想一想)?
在这里我们可以发现,要想打印它,空格和星号的顺序是反着的。规律也就相反了!?
空格是:0,1,2,3,4,5,6。星号是11,9,7,5,3,1。?
?
2.代码
#include<stdio.h>
int main()
{
int i = 0;
int j = 0;
int n = 0;
int s = 0;
printf("请输入行数:");
scanf("%d", &n);
for (i = 0; i < n; i++)//行数
{
for (j = 1; j < n - i; j++)//每一行之前的空格
{
printf(" ");
}
for (s = 0; s < i * 2 + 1; s++)//打印星号
{
printf("*");
}
printf("\n");
}
for (i = 1; i < n; i++)//i=1,避免行重复
{
for (j = 0; j < i ; j++)
{
printf(" ");
}
for (s = 0; s < 2 * (n - i) - 1; s++)
{
printf("*");
}
printf("\n");
}
return 0;
}
上面的三角形和第一个图案相同,重点是第二个倒三角!?
首先还是先确定行数(n), 为了避免行数的重复,这里i从1开始。然后是每行星号之前的空格,这里我们直接使用(j<i)可以很好的打印出空格,0,1,2,3,4,5,6。
最后就是打印星号,根据从大到小的规律:11,9,7,5,3,1。每个数都可以用2*(n-i)-1,得到,并且依次递减。?
三.打印V形?
1.图案?
根据前面的两个图形,我们也总结了一定的经验。(这里可以认真仔细的想一想)?
大概可以分为3部分:每行之前的空格,中间的空格,两边的星号!(比较难的便是中间部分的空格)?
?
?2.代码
int main()
{
int i = 0;
int j = 0;
int n = 0;
int s = 0;
printf("请输入行数:");
scanf("%d", &n);
for (i = 0; i < n; i++)//行数
{
for (j = 0; j < i; j++)//每行之前的空格
{
printf(" ");
}
printf("*");
for (s = 0; s < 2 * (n - i-1) - 1; s++)//打印中间的空格
{
printf(" ");
}
if (2 * (n - i - 1) - 1 > 0)//避免最后一行星号重复
{
printf("*");
}
printf("\n");
}
return 0;
}
?看完这个,是不是感觉和倒三角差不多,中间变成空格了!
第一步还是先确定变量,和行数。第二步就是每行之前的空格0,1,2,3,4,5,6........,直接用(j<i)就可以打印出来。打印空格之后,再打印一个星号,就完成一小半了。?
第三步就是中间的空格,看过之后可以发现中间空格是:13,11,9,7,5,3,1,0。根据之前的经验我们找规律,行数(n)-i-1再乘2可以得到每行的数是?14,12,10......并不是我们想要的数,但是只要在后面-1,就可以得到数了。主要还是用行数-当前的行数,再根据所得的结果进行加或减,来求得我们所需要的数字!
中间空格完成之后,再跟上星号。但是有一点要注意:就是最后一行星号重复的问题,如果不解决就无法打印出来,?这里会多一个。
?所以我们加上条件来完成:if (2 * (n - i - 1) - 1 > 0),大于0,就进行打印,当最后一行等于0时,条件不成立,就不执行打印。
四.打印(倒着的)V?
1.图案?
这个要将V反过来打印,每行之前的空格,星号,中间的空格,都要做一定的修改来完成。?
图形的规律还是可以找到的。?
?
?2.代码
这里是重新写的一段,和上一个分开了。?
int main()
{
int i = 0;
int j = 0;
int n = 0;
int s = 0;
printf("请输入行数:");
scanf("%d", &n);
for (i = 0; i < n; i++)//行数
{
for (j = 1; j < n - i; j++)//打印每行之前的空格
{
printf(" ");
}
if (n - i < n)//避免第一行星号重复
{
printf("*");
}
for (s = 0; s < i*2-1; s++)//打印中间的空格
{
printf(" ");
}
printf("*");//打印星号
printf("\n");
}
return 0;
}
?这里每行之前的空格用(j<n-i)来完成,规律是从大到小。然后这里开头在第一行,为了避免重复,使用条件来控制if(n-i<n),让第一行少打印一个星号。
中间空格从小到大:0,1,3,5,7,9,11,13。用(i*2-1)?可以得到,最后跟着打印每行的星号然后换行就完成了!!!!!!
总结
这里用C语言打印了几个图形,根据行和列来找到规律,进行打印。最好是多看一看,找到它的规律,就很好的打印出来了!
当然这里只是其中的一种方法,如果有更好的方法可以留言互相交流!
|