| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4116 人关注过本帖
标题:求大神看看这个为什么在OJ上显示格式错误
只看楼主 加入收藏
猴开森
Rank: 1
等 级:新手上路
帖 子:45
专家分:0
注 册:2016-11-27
结帖率:60%
收藏
 问题点数:0 回复次数:10 
求大神看看这个为什么在OJ上显示格式错误
题目描述

n 个人围成一圈, 并依次编号1~n,。从编号为1 的人开始,按顺时针方向每隔一人选出一个,剩下的人重新围成一圈,如此循环直到剩下两人,这剩下的两人就是幸运儿。如果你想成为最后两个幸运儿,请问开始时应该站在什么位置?(设3<=n<=50)

输入

有多个测试序列。每行是开始时的人数n

输出

第1 行是选出顺序,第2 行是两名幸运儿的开始位置(按升序排列),位置编号之间用一个空格分开。

样例输入

12
20
45

样例输出

2 4 6 8 10 12 3 7 11 5
1 9
2 4 6 8 10 12 14 16 18 20 3 7 11 15 19 5 13 9
1 17
2 4 6 8 10 12 14 16 18 20 22 24 26 28 30 32 34 36 38 40 42 44 3 7 11 15 19 23 27 31 35 39 43 5 13 21 29 37 45 9 25 41 17
1 33

#include<stdio.h>
int main()
{
    int n;
    while(scanf("%d",&n)!=EOF)
    {
        int a[999]={0},c[999]={0},i,*p,m=0,j=0,d[999]={0},e[999]={0},g[999]={0};
        for(i=0;i<n;i++)
        {
            a[i]=i+1;
        }
        p=a;
        p++;
        while(*p!=0)
        {
            printf("%d ",*p);
            m++;
            *p=0;
            p+=2;
        }
        if(m<n-2)
        {
            j=0;
            for(i=0;i<n;i++)
            {
                if(a[i]!=0)
                {
                    c[j]=a[i];
                    j++;
                }
            }
            p=c;
            p++;

            while(*p!=0)
            {
                printf("%d ",*p);
                *p=0;
                m++;
                p+=2;
            }
        }

        if(m<n-2)
        {
            j=0;
            for(i=0;i<n;i++)
            {
                if(c[i]!=0)
                {
                    d[j]=c[i];
                    j++;
                }
            }
            p=d;
            p++;
            while(*p!=0)
            {
                printf("%d ",*p);
                *p=0;
                m++;
                p+=2;
            }

        }
        if(m<n-2)
        {
            j=0;
            for(i=0;i<n;i++)
            {
                if(d[i]!=0)
                {
                    e[j]=d[i];
                    j++;
                }
            }
            p=e;
            p++;
            while(*p!=0)
            {
                printf("%d ",*p);
                *p=0;
                m++;
                p+=2;
            }

        }
        if(m<n-2)
        {
            j=0;
            for(i=0;i<n;i++)
            {
                if(e[i]!=0)
                {
                    g[j]=e[i];
                    j++;
                }
            }
            p=g;
            p++;
            while(*p!=0)
            {
                printf("%d ",*p);
                *p=0;
                m++;
                p+=2;
            }

        }
        printf("\n1 ");
        if(n>=3&&n<=4)
        {
            for(i=1;i<n;i++)
            {
                if(a[i]!=0)
                {
                    printf("%d\n",a[i]);
                }
            }

        }
        if(n>=5&&n<=8)
        {
            for(i=1;i<n;i++)
            {
                if(c[i]!=0)
                {
                    printf("%d\n",c[i]);
                }
            }

        }
        if(n>=9&&n<=16)
        {
            for(i=1;i<n;i++)
            {
                if(d[i]!=0)
                {
                    printf("%d\n",d[i]);
                }
            }

        }
        if(n>=17&&n<=32)
        {
            for(i=1;i<n;i++)
            {
                if(e[i]!=0)
                {
                    printf("%d\n",e[i]);
                }
            }
        }
        if(n>=33&&n<=50)
        {
            for(i=1;i<n;i++)
            {
                if(g[i]!=0)
                {
                    printf("%d \n",g[i]);
                }
            }
        }

    }
        return 0;
}
搜索更多相关主题的帖子: 顺时针 幸运儿 
2017-01-24 22:48
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
收藏
得分:0 
貌似弄错了些什么,编辑掉。

[此贴子已经被作者于2017-1-24 23:22编辑过]


09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-01-24 23:13
炎天
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:桃花岛
等 级:贵宾
威 望:29
帖 子:1218
专家分:4986
注 册:2016-9-15
收藏
得分:0 
是不是写得麻烦些了, 实例20 , 45 答案不对
程序代码:
#include<stdio.h>
int ar[1031];

int main(void) 
{
    int N;
    int i, j=0;
    int fla ;
    scanf("%d", &N);
    fla = N;
    for(i = 1; i <= N ; i++)
    {
        ar[i] = 1;                   //标志 ar[i]=1表示还活着 
    }
    
    while(fla > 2)                   //fla表示还剩下几个人 
    {
        while(1)
        {
           j++;
            if(ar[(N+1+j)%(N+1)] == 1)    //依次找到连续挨着的两个活的人 
           {
                 k++;                    
           }
           if(k == 2)                   //k=2表示找齐了 
           {
                 ar[(N+1+j)%(N+1)] = 0;               //刚刚找到的第二个人死了 
                 printf("%-3d", (N+1+j)%(N+1));      //输出刚刚找到的第二个人(现在死了) 
                 fla--;                              //总的活人少一个 
                 k = 0;
                 break;
           }
        }
    }
    
    printf("\n");
    for(i = 1; i <= N; i++)
    {
        if(ar[i] == 1)           //ar[i]=1表示i号人还活着 
        {
            printf("%d  ", i);
        }
    }
    
    return 0;

 } 

早知做人那么辛苦!  当初不应该下凡
2017-01-24 23:51
吹水佬
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册:2014-5-20
收藏
得分:0 
是不是这意思:
如:10个号,5号和9号是幸运号。
图片附件: 游客没有浏览图片的权限,请 登录注册

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void _move(int *a, int n, int m)
{
    int i;
    for (i=0; i<m; i++)
    {
        a[n] = a[0];
        memmove(a, a+1, n*sizeof(int));
    }
}

void _print(int *a, int n)
{
    int i;
    printf("选出%2d号人, 剩下的人:", a[0]);
    for (i=1; i<n; i++)
        printf("%2d ", a[i]);
    printf("\n");
}

main()
{
    int N=10;
    int i, n=N, m=2, k=2;
    int *a = (int *)malloc((n+1)*sizeof(int));
    for (i=0; i<n; i++)
        a[i] = i+1;
    _move(a, n, k-1);
    while (n > 2)
    {
        _print(a, n);
        memmove(a, a+1, --n*sizeof(int));
        _move(a, n, m-1);
    }
    printf("%d个人围成一圈,从第%d号人开始,按顺时针方向每隔%d人选出一个,最后剩下的两号人就是幸运儿。\n", N,k,m);
    free(a);
}

2017-01-25 07:03
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
为啥约瑟夫环问题这么火~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-01-25 08:09
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:0 
是约瑟夫环。
规律如下:
第一遍去掉 2 4 6 8 10 …… // 从 2的0次方+1 开始,步长 2的1次方
第二遍去掉 3 7 11 15 19 …… // 从 2的1次方+1 开始,步长 2的2次方
第三遍去掉 5 13 21 29 37 …… // 从 2的2次方+1 开始,步长 2的3次方
第四遍去掉 9 25 41 57 73 …… // 从 2的3次方+1 开始,步长 2的4次方

故有代码:
程序代码:
#include <stdio.h>

int main( void )
{
    unsigned n;
    while( scanf("%u",&n) == 1 )
    {
        unsigned a=2, b=2, m=0; // 开始、步长、输出数量

        for(  ; m!=n-2; a+b>n?(a=b+1,b*=2):(a+=b), ++m ) // 输出 n-2 个被淘汰的数
            printf( "%u ", a );

        printf( "\n%u %u\n", 1, a ); // 输出余下的两个数
    }
}

假如第一行末尾不许有空格,则可以改成
        for(  ; m!=n-2; a+b>n?(a=b+1,b*=2):(a+=b), ++m ) // 输出 n-2 个被淘汰的数
            printf( "%u%c", a, " \n"[m==n-3] );

        printf( "%u %u\n", 1, a ); // 输出余下的两个数

2017-01-25 09:49
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 6楼 rjsp
我还是得认真看题才行~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-01-25 10:06
猴开森
Rank: 1
等 级:新手上路
帖 子:45
专家分:0
注 册:2016-11-27
收藏
得分:0 
从编号为1 的人开始,按顺时针方向每隔一人选出一个,剩下的人重新围成一圈,如此循环
也就是说,每次都从1开始,不是一直隔一人选一个,而是每选完一圈后就又从1开始,所以1永远不会被选出来,1就是其中一个幸运儿
2017-01-25 10:46
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
感觉围成一圈有什么意义呢~我看到圈圈还以为是约瑟夫环问题~其实按输出格式来看根本就不是~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-01-25 11:28
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
收藏
得分:0 
回复 9楼 九转星河
我刚开始也以为是,于是复制了我在另外一个帖子的代码,然后才发现原来不是…………

09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-01-25 13:15
快速回复:求大神看看这个为什么在OJ上显示格式错误
数据加载中...
 
   



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

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