标题:出对序列
只看楼主
双子若尘
Rank: 1
来 自:福州
等 级:新手上路
帖 子:21
专家分:0
注 册:2012-12-13
结帖率:100%
已结贴  问题点数:18 回复次数:3 
出对序列

有N个人按照顺时针围成一圈,编号1到N。他们从1开始按顺时针报数,每报到M的人出列,并从下一个开始报数,报到M的人再出列,直到全部出列,请问你能给出这N个人的出队顺序吗?




输入格式


输入只有一行,包括两个整数N,M(2<=N,M<=1000)




输出格式


输出一行N个数,代表出队序列,每两个数之间用一个空格隔开。




样例输入


7 3




样例输出


3 6 2 7 5 1 4




#include<stdio.h>
#include<stdlib.h>
#define len sizeof(struct s)
struct s
{
    int num;
    struct s * next;
};
int main ()
{
    int k,n,m,i,j,t;
    struct s *p,*p1,*p2;
    struct s *head,*head1,*last1,*last,*r;
    scanf("%d %d",&n,&m);
    for(i=0;i<n;i++)                     
    {
       t=1;
 p1=(struct s*)malloc(len);
 p2=p1;
p1->num=t;head=NULL;
while(t<n)                        //创建链表,每个节点的NUM为它的序号
{
    if(t==1)
        head=p1;
    else
        p2->next=p1;
p1=(struct s*)malloc(len);
t++;
p1->num=t;
}
p1->next=NULL;
last=p1;
p1=p2=head;
head1=NULL;
t=n;j=1;
while(t!=0)
{
    if(t==n-1)                                 //若只剩一个结点,直接放在新链表的表尾
    {
        p=head;
        last1->next=p;
        last=p;
        p->next=NULL;
    }
    else
    {
    if(j==m)                                        //若j等于m,则开始将此节点移除旧链表,插进新链表
    {
        p=p1;                                                //先删
        if(p1==last)                                     //若在表尾,
        {
            p2->next=NULL;
            last=p2;
            p1=head;
        }
        else if(p1==head)                                //在表头
        {
            head=p1->next;
            p1=p1->next;
            p2=head;
        }
        else
        {                                                            //在表中
            p2->next=p1->next;
            p1=p1->next;
        }
        j=1;t--;p->next=NULL;                                            //插入新表
        if(head1==NULL)
        {                                                                   //新表为空
            head1=p;
            last1=p;
        }
        else                                                                 //插在表尾
        {
            last1->next=p;
            last=p;
        }
    }
    else                                                                           //若j不等于m,
    {
        if(p1==last)                                                             //若轮到表尾,返回表头
        {
            p2=p1;
           p1=head;
        }                                                                               //若在表中,正常往下轮
        else
        {
            p2=p1;
            p1=p1->next;
        }
        j++;
    }
    }
}
    }
r=head1;                                                                     // 输出新链表
 while(r!=NULL)
      {
       printf("%d ",r->num);                        
       r=r->next;
      }
      printf("\n");
      return 0;
    }
搜索更多相关主题的帖子: include 顺时针 
2013-01-05 14:47
双子若尘
Rank: 1
来 自:福州
等 级:新手上路
帖 子:21
专家分:0
注 册:2012-12-13
得分:0 
回复 楼主 双子若尘
请问,它错哪儿了?只有光标闪呐闪
2013-01-05 14:50
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
得分:18 
代码好长,没有细看,我运行了下没有出现楼主说的只有光标闪的情况(刚开始也有,但是细看发现那是等待输入),但是试着运行了下发现楼主的代码有问题,在运行时红色部分会报错
         p1=head;
        }                                                                              
        else
        {
            p2=p1;
            p1=p1->next;//这里
        }
        j++;
    }

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2013-01-05 15:07
双子若尘
Rank: 1
来 自:福州
等 级:新手上路
帖 子:21
专家分:0
注 册:2012-12-13
得分:0 
可是这个为什么会错呢,在其他程序中,他很正常啊
2013-01-05 15:36



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




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

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