| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1460 人关注过本帖
标题:晚自习两个钟头,就这个题目,硬是没有做出来。。
只看楼主 加入收藏
吴军旗
Rank: 5Rank: 5
等 级:职业侠客
帖 子:286
专家分:308
注 册:2011-9-14
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:15 
晚自习两个钟头,就这个题目,硬是没有做出来。。
有N个人围成一圈,顺序排号,从第一个人开始报数( 从1到3 ),凡报到3的人退出圈子,问最后留下的是原来第几号的那位?
搜索更多相关主题的帖子: 晚自习 
2011-10-26 01:33
吴军旗
Rank: 5Rank: 5
等 级:职业侠客
帖 子:286
专家分:308
注 册:2011-9-14
收藏
得分:0 
明天来看,睡觉去了。。。

最惨的不是忘不了悲伤的回忆,而是那些悲伤的回忆却开始记不清。。。
2011-10-26 01:35
embed_xuel
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:58
帖 子:3845
专家分:11385
注 册:2011-9-13
收藏
得分:1 
回复 2楼 吴军旗
约瑟夫环,实在做不出来可以问百度谷哥

总有那身价贱的人给作业贴回复完整的代码
2011-10-26 07:12
吴军旗
Rank: 5Rank: 5
等 级:职业侠客
帖 子:286
专家分:308
注 册:2011-9-14
收藏
得分:0 
无语

最惨的不是忘不了悲伤的回忆,而是那些悲伤的回忆却开始记不清。。。
2011-10-26 07:31
hjywyj
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:3
帖 子:1114
专家分:2611
注 册:2010-4-14
收藏
得分:1 
约瑟夫环问题,百度一下,代码一大堆
2011-10-26 07:41
ppfly
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
帖 子:297
专家分:1956
注 册:2009-5-17
收藏
得分:1 
楼主不是最近在看链表么,那我给你一个约瑟夫环的循环链表算法,你指正指正
程序代码:
/*
程序采用循环链表的算法实现
m个人围成圈,报到n的人退出,求最后一位的原始编号
*/
#include "stdio.h"
#include "stdlib.h"
#include "conio.h"
long int m,n;
struct node *h;
struct node /*链表结点结构*/            
{
  struct node *next;
  int data;
};
struct node * create(struct node *h)  /*创建单向循环链表*/
{
  struct node *p,*q; int i;
  h=p=q=(struct node *)malloc(sizeof(struct node));
  p->next=NULL; p->data=1;
  for(i=2;i<=m;i++)
   {
     p=(struct node *)malloc(sizeof(struct node));
     q->next=p; p->data=i; p->next=NULL;
     q=p;
   } 
  p->next=h;
  return h;
}
int fun(struct node *h)  /*操作链表*/
{
  struct node *p=h,*q; int i;
  if(n>1)
  {
      while(p->next!=p)
      {
        i=1;
        while(i<n-1) {p=p->next; i++;}
        q=p->next;
        p->next=q->next;q->next=NULL;
        free(q);
        p=p->next;
      }
  }
  else if(n==1)
  {
      p->data=m;
  }
  return p->data;
}
int main()
{
  struct node *h;
  printf("请输入总人数m:");
  scanf("%d",&m);
  printf("再输入退出者号n:");
  scanf("%d",&n);
  h=create(h);
  printf("最后一位号码是:");
  printf("%d\n",fun(h));
  return 0;
}



********多贴代码,少说空话*******
2011-10-26 10:48
吴军旗
Rank: 5Rank: 5
等 级:职业侠客
帖 子:286
专家分:308
注 册:2011-9-14
收藏
得分:0 
回复 6楼 ppfly
一直相信有牛人,年来没有错,我ctrl+c  去研究下,,

最惨的不是忘不了悲伤的回忆,而是那些悲伤的回忆却开始记不清。。。
2011-10-26 12:45
haiki
Rank: 1
等 级:新手上路
帖 子:11
专家分:4
注 册:2011-10-25
收藏
得分:1 
我也在看链表,粘贴回去研究一下。
2011-10-26 13:14
ningye
Rank: 2
等 级:论坛游民
帖 子:33
专家分:22
注 册:2011-9-22
收藏
得分:1 
程序代码:
#include<stdio.h>
#define N 10
main()
{
    int n,m,i,k=0;
    int a[N];
    n=N;
    for(i=0;i<N;i++)
    a[i]=i+1;
    printf("input the number:");
    scanf("%d",&m);                       /*令m=3就好*/
    while(n>1)
    {
        if(i==N)
            i=0;
        if(a[i])
            k++;
        if(k==m)
        { 
            printf("a[%d]=%-5d",i,a[i]); /*被删除的数*/
            a[i]=0;
            k=0;
            n--;
        }
           i++;
    }
    i=-1;
    while(!a[++i]);                    /*剩下的数*/
    printf("\na[%d]=%d\n",i,a[i]);
    return 0;
}
建议你换一下头像,看着不舒服。
2011-10-26 20:39
hhdong123
Rank: 2
等 级:论坛游民
帖 子:8
专家分:25
注 册:2011-10-21
收藏
得分:1 
回复 楼主 吴军旗
呵呵  其实不是很难  动动脑筋就行了
程序代码:
/* Note:Your choice is C IDE */
#include "stdio.h"
#include "malloc.h"
/*#define NULL 0*/
#define LEN sizeof(struct person)
struct person
{
    int num;
    struct person *next;   
};
int n;
struct person *create(void)
{  struct person *head,*p1,*p2;
n=0;
p1=p2=(struct person*)malloc(LEN);
head=p1;
while(n!=13)
{
    n=n+1;
    p2->num=n;
    if(n!=13)
    {
    p1=(struct person*)malloc(LEN);
    p2->next=p1;
    p2=p1;
    }
}
p2->next=NULL;
return(head);
}
void print(struct person *head)
{
    struct person *p;
    p=head;
    if(head!=NULL)
    {do
    {
        printf("%d   ",p->num);
        p=p->next;
    }while(p!=NULL);
    printf("\n");}
    else
    printf("error");
}
struct person *select(struct person *head)
{ struct person *heads,*p,*q;
    static i=1;
    heads=head;
    q=p=heads;
    while(p!=NULL)
    {
        if(i%3!=0)
        {
            q=p;
            p=p->next;
        i=i+1;
        }
        else
        {   if(p!=heads)
            q->next=p->next;       
        else {
            heads=p->next;
            q=heads;
             }
            p=p->next;
            i=i+1;
            n=n-1;}
    }
     if(n>1){heads=select(heads);}
    return (heads);
   
    }
void main()
{
    struct person *head;
    head=create();
    print(head);
    head=select(head);
    print(head);
   
}
我也是新手,多思考!!出现了问题自己查找错误 多动手调试就行了!!!
2011-10-27 21:49
快速回复:晚自习两个钟头,就这个题目,硬是没有做出来。。
数据加载中...
 
   



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

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