| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 939 人关注过本帖
标题:约瑟夫环的问题
取消只看楼主 加入收藏
leon57
Rank: 1
来 自:xznu
等 级:新手上路
帖 子:29
专家分:0
注 册:2008-7-19
收藏
 问题点数:0 回复次数:0 
约瑟夫环的问题
#include<stdio.h>
#include<stdlib.h>

typedef void Status;
typedef int ElemType;

typedef struct CLnode
{
    ElemType data;
    struct CLnode *next;
}CLnode,*CLinkList;

Status InitList(CLinkList &L)
{
    L=(CLinkList)malloc(sizeof(CLnode));
    L->next=NULL;
}

Status CreateList_L(CLinkList &L,int n)//建立链表
{
    CLinkList p;
    int i;
    InitList(L);
        for(i=n;i>0;i--)
        {
            p=(CLinkList)malloc(sizeof(CLnode));
            scanf("%d",&p->data);
            p->next=L->next;
            L->next=p;
        }

}
Status ReverseList_L(CLinkList &L,int n)//倒置
{


    CLinkList p;
    CLinkList a;
    CLinkList b;
    a=L;
    p=a->next;
    a->next=NULL;

        b=p->next;
        p->next=a;
        a=p;
        p=b;
    while(p->next!=NULL)
    {
        b=p->next;
        p->next=a;
        a=p;
        p=b;
    }

    p->next=a;
    L->next=p;
    p=L->next;
}




Status JOSEPHUS(CLinkList &L,int n,int k,int m)//约瑟夫环环
{


    CLinkList p;
    CLinkList r;
    int i;
    p=L->next;
    for(i=0;i<k;i++)
    {
    
        p=p->next;
    }
    while(p->next!=p)
    {
        for(i=0;i<m;i++)
        {
            if(p->next!=NULL)
            {r=p;
            p=p->next;}
            else
            {
                p->next=L->next;
                r=p;
                p=p->next;
            }

        }
        p=p->next;
        r->next=p->next;
        free(p);
        p=r->next;
    }
    printf("\n最后被删除的元素是:%4d\n",p->data);

}


void main()
{
    int n,m,k;
    printf("请输入元素的个数:");
    scanf("%d",&n);
    CLinkList L;
    CreateList_L(L,n);
    ReverseList_L(L,n);
    printf("请输入开始报数的人的序号:");
    scanf("%d",&k);
    printf("请输入出列者喊出的数:");
    scanf("%d",&m);
    JOSEPHUS(L,n,k,m);
}


约瑟夫环无法实现??
搜索更多相关主题的帖子: 约瑟夫 
2008-10-12 21:41
快速回复:约瑟夫环的问题
数据加载中...
 
   



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

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