输入:
n
输出:
数字菱形
友情提示:同学们总结一下打印星号组成的实心图形程序的编程思路:第一步,打印星号组成的正方形;第二步,改变每行星号的个数,打印每行星号数量不一样的图形;如果是空心图形,每行第一个和最后一个位置输出星号,其他位置输出空格。
现在我们练习输出变化的字符,在打印星号图形的基础上,原来输出号的位置,将printf("");改为printf("%2d",x);当然,原来输出一个*号的地方只占一个字符的位置,现在都要改为2个字符的位置,如果输出的是数字且多于2个,则要是%3d或%4d了。
x是多少呢?则要寻找其规律,就是该输出位置与所在行列的关系。
注意给出的测试用例,输出的数字是左对齐啊。不用数组就可以完成。
测试用例
输入
3↵
输出
3 ↵
3 2 3 ↵
3 2 1 2 3 ↵
3 2 3 ↵
3 ↵
代码
#include<stdio.h>
#include<stdlib.h>
main()
{
int n,i,j,current;scanf("%d",&n);//输入数字菱形的关键数(最大数)
int max=2*n-1;//max为菱形中间行的元素个数,也是菱形的行数
for(i=1;i<=max;i++)//i为当前行数
{
for(j=1;j<=max-abs(i-n);j++)//j为行数下的列数,第i行的元素个数由第i行和中间行(第n行)的间隔确定
{
current=1+abs(i-n)+abs(j-n);
//对于第i行,第n列(菱形的中心线)上的元素为1+abs(i-n),以此为基准,确定第j列的元素为+abs(j-n)
if(current>n) printf(" ");
//如果元素超过外围数(关键数),打印空格
else printf("%-2d",current);
//不超过则打印数字
}
printf("\n");//打印完每行后换行
}
}
n=8的输出结果
8↵
8 ↵
8 7 8 ↵
8 7 6 7 8 ↵
8 7 6 5 6 7 8 ↵
8 7 6 5 4 5 6 7 8 ↵
8 7 6 5 4 3 4 5 6 7 8 ↵
8 7 6 5 4 3 2 3 4 5 6 7 8 ↵
8 7 6 5 4 3 2 1 2 3 4 5 6 7 8 ↵
8 7 6 5 4 3 2 3 4 5 6 7 8 ↵
8 7 6 5 4 3 4 5 6 7 8 ↵
8 7 6 5 4 5 6 7 8 ↵
8 7 6 5 6 7 8 ↵
8 7 6 7 8 ↵
8 7 8 ↵
8 ↵