数字菱形
这是非信息类2013年出的题目,大家来看看,你会做吗?输入 n 的值,输出如下例( n=4 )所示的数字菱形。
4
434
43234
4321234
43234
434
4
输入:
n
输出:
数字菱形
友情提示:同学们总结一下打印星号组成的实心图形程序的编程思路:第一步,打印星号组成的正方形;第二步,改变每行星号的个数,打印每行星号数量不一样的图形;如果是空心图形,每行第一个和最后一个位置输出星号,其他位置输出空格。
现在我们练习输出变化的字符,在打印星号图形的基础上,原来输出*号的位置,将printf("*");改为printf("%2d",x);当然,原来输出一个*号的地方只占一个字符的位置,现在都要改为2个字符的位置,如果输出的是数字且多于2个,则要是%3d或%4d了。
x是多少呢?则要寻找其规律,就是该输出位置与所在行列的关系。
注意给出的测试用例,输出的数字是左对齐啊。不用数组就可以完成。
测试用例 1 以文本方式显示
1.1↵
以文本方式显示
1.1 ↵
1秒 64M 0
测试用例 2 以文本方式显示
1.2↵
以文本方式显示
1. 2 ↵
2.2 1 2 ↵
3. 2 ↵
1秒 64M 0
测试用例 3 以文本方式显示
1.3↵
以文本方式显示
1. 3 ↵
2. 3 2 3 ↵
3.3 2 1 2 3 ↵
4. 3 2 3 ↵
5. 3 ↵
1秒 64M 0
测试用例 4 以文本方式显示
1.8↵
以文本方式显示
1. 8 ↵
2. 8 7 8 ↵
3. 8 7 6 7 8 ↵
4. 8 7 6 5 6 7 8 ↵
5. 8 7 6 5 4 5 6 7 8 ↵
6. 8 7 6 5 4 3 4 5 6 7 8 ↵
7. 8 7 6 5 4 3 2 3 4 5 6 7 8 ↵
8.8 7 6 5 4 3 2 1 2 3 4 5 6 7 8 ↵
9. 8 7 6 5 4 3 2 3 4 5 6 7 8 ↵
10. 8 7 6 5 4 3 4 5 6 7 8 ↵
11. 8 7 6 5 4 5 6 7 8 ↵
12. 8 7 6 5 6 7 8 ↵
13. 8 7 6 7 8 ↵
14. 8 7 8 ↵
15. 8 ↵
1秒 64M 0
测试用例 5 以文本方式显示
1.10↵
以文本方式显示
1. 10↵
2. 109 10↵
3. 109 8 9 10↵
4. 109 8 7 8 9 10↵
5. 109 8 7 6 7 8 9 10↵
6. 109 8 7 6 5 6 7 8 9 10↵
7. 109 8 7 6 5 4 5 6 7 8 9 10↵
8. 109 8 7 6 5 4 3 4 5 6 7 8 9 10↵
9. 109 8 7 6 5 4 3 2 3 4 5 6 7 8 9 10↵
10.109 8 7 6 5 4 3 2 1 2 3 4 5 6 7 8 9 10↵
11. 109 8 7 6 5 4 3 2 3 4 5 6 7 8 9 10↵
12. 109 8 7 6 5 4 3 4 5 6 7 8 9 10↵
13. 109 8 7 6 5 4 5 6 7 8 9 10↵
14. 109 8 7 6 5 6 7 8 9 10↵
15. 109 8 7 6 7 8 9 10↵
16. 109 8 7 8 9 10↵
17. 109 8 9 10↵
18. 109 10↵
19. 10↵
1秒 64M 0
怎么写?我的完全错了
#include<stdio.h>
int main()
{int n,i,j;
scanf("%d",&n);
for(i=1;i<=2*n-1;i++)
{for(j=1;j<=2*n;j++)
if((i<=n&&j==n+i)||(i>n&&j==3*n-i)) printf("\n");
if(i!=n&&i%n+j<=n) printf(" ");
else printf("%-2d",2*n+1-i-j);
}
return 0;
}