国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++循環鏈表之約瑟夫環的實現方法

2020-01-26 15:21:31
字體:
來源:轉載
供稿:網友

本文實例形式展示了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++程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鲁甸县| 沙洋县| 三江| 夏津县| 托里县| 屯留县| 左云县| 池州市| 克拉玛依市| 株洲市| 红桥区| 南召县| 沐川县| 陇南市| 大余县| 临汾市| 兰考县| 来安县| 美姑县| 股票| 甘孜县| 鄢陵县| 梁河县| 阿尔山市| 隆林| 大兴区| 建阳市| 临朐县| 双峰县| 五莲县| 铅山县| 加查县| 荣昌县| 苍山县| 黄陵县| 滕州市| 全州县| 大邑县| 汝阳县| 左云县| 临汾市|