标题:数字菱形
只看楼主
BIT112016197
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2016-10-18
结帖率:66.67%
已结贴  问题点数:10 回复次数:1 
数字菱形
这是非信息类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
书生牛犊
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:星夜征程
等 级:贵宾
威 望:10
帖 子:1101
专家分:5265
注 册:2015-10-27
得分:10 

说实话,你得搞个链接给我们或者搞个效果截图,复制进来的文本格式都乱掉了,根本看不出来所以然。所以我随便先写了一个。你看看和你的代码比较一下。把逻辑弄清楚。

1.搞清楚每行输出数据的规则,应该输出多少行
2.输出每行的前导空格
3.从大到小输出
4.从小刀打输出
5.回车

程序代码:
#include<stdio.h>
int main() {
    int n,i,j;
    scanf("%d",&n);
    for(int i=n;i>1;i--){
       

        for(j=1;j<i;j++)printf("__");//便于演示观察,所以使用下划线

        for(j=n;j>i;j--){
            if(j!=n)printf(" ");
        printf("%d",j);   

        }
        for(;j<=n;j++)printf(" %d",j);
        printf("\n");
    }
        for(int i=1;i<=n;i++){
       

        for(j=1;j<i;j++)printf("__");
        for(j=n;j>i;j--){
        if(j!=n)printf(" ");
        printf("%d",j);
        }
        for(;j<=n;j++)printf(" %d",j);
        printf("\n");
    }
    return 0;
}
再次声明一下,这段代码并不一定可以妥善解决题主所给出的问题,其中的格式控制需要做一些修改,比如左对齐,比如域宽,不过我是没看懂样例,所以...



[此贴子已经被作者于2016-10-22 17:49编辑过]


φ(゜▽゜*)♪
2016-10-22 17:45



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-470104-1-1.html




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

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