| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1434 人关注过本帖, 2 人收藏
标题:一道程序竞赛题,看了一下午没理出头绪,有高手帮忙看一下呗……
只看楼主 加入收藏
莫一阳
Rank: 1
等 级:新手上路
帖 子:38
专家分:6
注 册:2011-4-27
结帖率:78.57%
收藏(2)
已结贴  问题点数:20 回复次数:13 
一道程序竞赛题,看了一下午没理出头绪,有高手帮忙看一下呗……
请编程打印如下面图形
1  3  6  10  15
2  5  9  14
4  8  13
7  12
11
输入:
    测试例子中,一行给出一个整数N,(0<N<100);
输出:
    每一个测试例子,输出相对应的字符图形
例如输入:
3
5
对应输出:
1  3  6
2  5
4

1  3  6  10  15
2  5  9  14
4  8  13
7  12
11

搜索更多相关主题的帖子: 编程 竞赛题 
2011-10-18 16:49
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:3 
程序代码:
#include <stdio.h>
#include <string>
using namespace std;
int a[100][100] = {0};
int main()
{
    int i,j,n;
    while(EOF != scanf("%d",&n))
    {
        int k = 1;
        for(i = 0;i<n;i++)
        {
            int r = i;
            for(j = 0;j<=i;j++)
            {
                a[r][j] = k++;
                r--;
            }
        }
        for(i = 0;i<n;i++)
        {
            for(j = 0;j<n-i-1;j++)
            {
                printf("%d ",a[i][j]);
            }
            printf("%d\n",a[i][j]);
        }
    }
    return 0;
} 
这个题目思路为从左上角开始向右下角打印  打印规律为每一次打印的个数为所在行数 并且满足i+j = 行数

需要注意没有多余的空格 打印时应该写成如下形式
            for(j = 0;j<n-i-1;j++)
            {
                printf("%d ",a[i][j]);
            }
            printf("%d\n",a[i][j]);

                                         
===========深入<----------------->浅出============
2011-10-18 17:10
梦中的电子
Rank: 1
等 级:新手上路
帖 子:4
专家分:3
注 册:2011-10-18
收藏
得分:3 
2L好快
2011-10-18 17:30
莫一阳
Rank: 1
等 级:新手上路
帖 子:38
专家分:6
注 册:2011-4-27
收藏
得分:0 
回复 2楼 laoyang103
你好厉害哦,佩服佩服!!! 我是菜鸟,有些代码不怎么懂,特别是for循环那块,麻烦你能详细注释一下么?万分感谢……
2011-10-18 18:21
c821101017
Rank: 2
等 级:论坛游民
帖 子:33
专家分:10
注 册:2011-9-21
收藏
得分:3 
程序代码:
#include<stdio.h>
#include<stdlib.h>
void main()
{
    int m;
    int i,j;
    int **a;
    char flag='Y';
    while(flag=='Y')
    {
        printf("Please input a integer: ");
        scanf("%d",&m);
        a=(int **)calloc(m+1,sizeof(int *));
        for(i=0; i<m; i++)
            a[i]=(int *)calloc(m+1,sizeof(int ));
        a[0][0]=1;
        for(i=1; i<m; i++)
        {
            a[0][i]=i+1+a[0][i-1];
            a[i][0]=i+a[i-1][0];
        }
        for(i=1; i<m; i++)
            for(j=1; j<m-i; j++)
                a[i][j]=a[i-1][j]+j+i;
        for(i=0; i<m; i++)
        {
            for(j=0; j<m-i; j++)
                printf("%d ",a[i][j]);
            printf("\n");
        }
        printf("Do you want to continue?If yes,press Y,if not,press N.\n");
        getchar();
        scanf("%c",&flag);
        if(flag=='Y')
            continue;
        else break;
    }
}
2011-10-18 18:38
ningye
Rank: 2
等 级:论坛游民
帖 子:33
专家分:22
注 册:2011-9-22
收藏
得分:3 
程序代码:
#include<stdio.h>
void main()
{
int i,j,n,m=0,k=0,a[100][100];
scanf("%d",&n);
for(i=0;i<n;i++,m=i)   
for(j=0;j<i+1;j++,m--)
    a[m][j]=++k;  
for(i=0;i<n;i++)
{
    for(j=0;j<n-i;j++)
    printf("%3d",a[i][j]);
    printf("\n");
}
}
调试OK
2011-10-18 19:05
不要再信我
Rank: 2
等 级:论坛游民
帖 子:11
专家分:18
注 册:2011-10-17
收藏
得分:3 
以下是引用laoyang103在2011-10-18 17:10:34的发言:

#include  
#include  
using namespace std;
int a[100][100] = {0};
int main()
{
    int i,j,n;
    while(EOF != scanf("%d",&n))
    {
        int k = 1;
        for(i = 0;i
膜拜+学习了
2011-10-18 19:49
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
回复 6楼 ningye
注意把该加的花括号都加上  不要去省行  不然降低可读性

                                         
===========深入<----------------->浅出============
2011-10-18 21:00
神马都浮云
Rank: 2
等 级:论坛游民
帖 子:13
专家分:15
注 册:2011-7-11
收藏
得分:3 
程序代码:
#include"stdio.h"
int main()
{
    int m,i,j,k,flag;
    int a[100][100];

    k=1;
    scanf("%d",&m);

    for(flag=1;flag<=m;flag++)
    {       
        for(i=flag,j=1;i>=1&&j<=flag;i--,j++)
        {
            a[i][j]=k;
            k++;
        }
    }

    for(i=1;i<=m;i++)
    {
        for(j=1;j<=m-i+1;j++)
        {
            printf("%5d",a[i][j]);
        }
        printf("\n");
    }

    return 0;
}
2011-10-18 21:24
compiler
Rank: 2
等 级:论坛游民
帖 子:25
专家分:46
注 册:2011-7-27
收藏
得分:0 
速度真快
2011-11-02 16:20
快速回复:一道程序竞赛题,看了一下午没理出头绪,有高手帮忙看一下呗……
数据加载中...
 
   



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

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