菱形的实现
- 首先明确一点,将菱形分成上下两个部分来分别打印
- 下面分为几种情况(实心菱形,数字菱形和空性菱形)
实心菱形
应该明确菱形对角线有多长,也就是高度,一般都为奇数,如果是偶数,我们将其+1当作高度。我们要知道菱形的对角线和两部分。(假设对角线长L,那这里的 n=(L-1)/2 )
1.我们先使用一个大的for循环将每一行的空格和#输出。
2.再明确,每一行里面都有空格和#两个独立元素,所以我们需要两个for循环来分别输出空格与#.
3.第一个内循环for(int j=1;j<=n-i;j++),在输出完空格后,第二个内循环将在每一行的空格后面紧接着输出#。(即使第二个也是 j 开头,但是确实指一个新的循环,与上面的 j 无关)
#include <stdio.h>
int main(void)
{
int n,i,j;
scanf("%d",&n);
for(i=0;i<=n;i++)//上半部分
{
for(j=1;j<=n-i;j++)//每行前边空格
{
putchar(' ');
}
for(j=1;j<=2*i+1;j++)//*
{
putchar('*');
}
putchar('\n');
}
for(i=1;i<=n;i++)//下半部分
{
for(j=1;j<=i;j++)
{
putchar(' ');
}
for(j=2*(n-i)+1;j>0;j--)
{
putchar('*');
}
putchar('\n');
}
return 0;
}
数字菱形
与上面的实心菱形不同,n=(L+1)/2,在输入完空格之后,我们将会在每一行都依次打印1~n的数字,再打印(n-1) ~ 1的数字。此处应注意到。
1.两次for循环不同,上半部分书连着中轴线一起输出,下半部分不输出轴线,所以为for(int i=1;i<n;i++) n-1次循环。
2.由于下面的三角形是倒过来的吗,所以我们尽管是从i=1开始循环,但是任然要注意n的取值范围,所以b=n-i 与上面的b=i 是实现一样的功能(都是打印到竖直的中轴线处)
#include <stdio.h>
main()
{
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
for(int a=1;a<=n-i;a++)
{
putchar(' ');
}
for(int b=1;b<=i;b++)
{
printf("%d",b);
}
for(int c=i-1;c>=1;c--)
{
printf("%d",c);
}
printf("\n");
}
for(int i=1;i<n;i++)
{
for(int a=1;a<=i;a++)
{
putchar(' ');
}
for(int b=1;b<=n-i;b++)
{
printf("%d",b);
}
for(int c=n-i-1;c>0;c--)
{
printf("%d",c);
}
printf("\n");
}
}
两次的n不相同是有原因的,这里想让大家明白,n的取值是由轴线的归属和上下三角形决定的,不是一尘不变的。