栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C++循环链表之约瑟夫环的实现方法

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C++循环链表之约瑟夫环的实现方法

本文实例形式展示了C++实现循环链表中约瑟夫环的方法,分享给大家供大家参考之用。具体方法如下:

主要功能代码如下:

#include 
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<data<<" ";
  p=p->next;
 }while(p!=head);//这里出现过问题,用do-while
 cout<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<data<next;//mend指向报数的人;
 free(deletem); //最后删除 
 }
}
int main(){
 Josephus(13,4,1);
 return 0;
}

希望本文所述对大家的C++程序设计有所帮助。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/65497.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号