| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 6421 人关注过本帖
标题:数字菱形
取消只看楼主 加入收藏
BIT112016197
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2016-10-18
结帖率:66.67%
收藏
已结贴  问题点数:10 回复次数:0 
数字菱形
这是非信息类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;
}
搜索更多相关主题的帖子: 信息 正方形 
2016-10-22 15:50
快速回复:数字菱形
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015779 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved