C++循環(huán)鏈表之約瑟夫環(huán)的實(shí)現(xiàn)方法
更新時(shí)間:2014年09月02日 16:00:27 投稿:shichen2014
這篇文章主要介紹了C++循環(huán)鏈表之約瑟夫環(huán)的實(shí)現(xiàn)方法,對(duì)于學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)與算法有一定的借鑒價(jià)值,需要的朋友可以參考下
本文實(shí)例形式展示了C++實(shí)現(xiàn)循環(huán)鏈表中約瑟夫環(huán)的方法,分享給大家供大家參考之用。具體方法如下:
主要功能代碼如下:
#include <iostream>
using namespace std;
typedef struct student
{
int data;
struct student* next;
}node,*LinkList;
//約瑟夫環(huán)
void printfList(LinkList head){
LinkList p=head;
if (head!=NULL)
{
do{
cout<<p->data<<" ";
p=p->next;
}while(p!=head);//這里出現(xiàn)過(guò)問(wèn)題,用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個(gè)開(kāi)始
while(n--){//要全部輸出
int mm=1;
pre=mend;//每次都要給pre從新復(fù)值否則程序錯(cuò)誤
while(mm!=m){//不是要求的數(shù),指針每次往前推一步,mend指向報(bào)數(shù)的人,pre指向前一個(gè)
pre=mend;
mend=mend->next;
mm++;
}
pre->next=mend->next;//前一個(gè)鏈到下一個(gè)準(zhǔn)備報(bào)數(shù)的
cout<<mend->data<<endl;
LinkList deletem=mend;
mend=pre->next;//mend指向報(bào)數(shù)的人;
free(deletem); //最后刪除
}
}
int main(){
Josephus(13,4,1);
return 0;
}
希望本文所述對(duì)大家的C++程序設(shè)計(jì)有所幫助。
相關(guān)文章
詳細(xì)對(duì)比C語(yǔ)言中的chmod()函數(shù)和fchmod()函數(shù)
這篇文章主要介紹了C語(yǔ)言中的chmod()函數(shù)和fchmod()函數(shù)的詳細(xì)對(duì)比,兩個(gè)都是用于修改文件權(quán)限但是請(qǐng)注意實(shí)際使用上的差異,需要的朋友可以參考下2015-09-09
c++代碼實(shí)現(xiàn)tea加密算法的實(shí)例詳解
這篇文章主要介紹了c++代碼實(shí)現(xiàn)tea加密算法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
C語(yǔ)言詳解如何實(shí)現(xiàn)帶頭雙向循環(huán)鏈表
帶頭雙向循環(huán)鏈表:結(jié)構(gòu)最復(fù)雜,一般用在單獨(dú)存儲(chǔ)數(shù)據(jù)。實(shí)際中使用的鏈表數(shù)據(jù)結(jié)構(gòu),都是帶頭雙向循環(huán)鏈表。另外這個(gè)結(jié)構(gòu)雖然結(jié)構(gòu)復(fù)雜,但是使用代碼實(shí)現(xiàn)以后會(huì)發(fā)現(xiàn)結(jié)構(gòu)會(huì)帶來(lái)很多優(yōu)勢(shì),實(shí)現(xiàn)反而簡(jiǎn)單2022-04-04

