C++循环链表之约瑟夫环的实现方法
2014-09-02 16:00
721 查看
本文实例形式展示了C++实现循环链表中约瑟夫环的方法,分享给大家供大家参考之用。具体方法如下:
主要功能代码如下:
#include <iostream> using namespace std; typedef struct student { int data; struct student* next; }node,*LinkList; //约瑟夫环 void printfList(LinkList head){ LinkList p=head; if (head!=NULL) { do{ cout<<p->data<<" "; p=p->next; }while(p!=head);//这里出现过问题,用do-while cout<<endl; } } void Josephus(int n,int k,int m){ int i=2; LinkList head=(LinkList)malloc(sizeof(node)); head->next=head; head->data=1; LinkList pre=head; while(i<=n){ LinkList p=(LinkList)malloc(sizeof(node)); p->data=i; p->next=pre->next; pre->next=p; pre=p; i++; } printfList(head); LinkList mend=pre; int kk=0; while(kk!=k){ mend=mend->next; ++kk; }//找到k个开始 while(n--){//要全部输出 int mm=1; pre=mend;//每次都要给pre从新复值否则程序错误 while(mm!=m){//不是要求的数,指针每次往前推一步,mend指向报数的人,pre指向前一个 pre=mend; mend=mend->next; mm++; } pre->next=mend->next;//前一个链到下一个准备报数的 cout<<mend->data<<endl; LinkList deletem=mend; mend=pre->next;//mend指向报数的人; free(deletem); //最后删除 } } int main(){ Josephus(13,4,1); return 0; }
希望本文所述对大家的C++程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- 用C++实现单向循环链表的解决方法
- 双向循环链表的c++ 实现
- 约瑟夫环的实现-链表方法
- C++实现有哨兵的双向循环链表
- 双向循环链表的C++实现
- 循环链表 约瑟夫环问题实现
- 伪多态的循环链表C++实现【多类型支持】
- 队列(queue)的链表(list)实现及循环数组(circular array)实现 C++实现
- (C++版)链表(二)——实现单项循环链表创建、插入、删除等操作
- 链表初解(三)——约瑟夫环之循环链表实现
- 使用C++实现的单向循环链表
- 数据结构学习系列三-单向循环链表(c++实现且应用模板)
- C++类模板 实现双向循环链表的基本算法 《数据结构》(C++版 北京科海)中摘抄
- (C++版)链表(四)——实现双向循环链表创建、插入、删除等简单操作
- 双向循环链表删除算法的C++程序实现
- C++实现循环链表
- 单向循环链表的实现以及约瑟夫环的实现
- C++实现数据结构三 双向循环链表
- C++链表倒序实现方法
- C语言:链表的循环,两种思考方法,第一种用select_1()实现,第二种用select_2()实现.