C++循環(huán)鏈表之約瑟夫環(huán)的實現(xiàn)方法
本文實例形式展示了C++實現(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)過問題,用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從新復(fù)值否則程序錯誤
while(mm!=m){//不是要求的數(shù),指針每次往前推一步,mend指向報數(shù)的人,pre指向前一個
pre=mend;
mend=mend->next;
mm++;
}
pre->next=mend->next;//前一個鏈到下一個準(zhǔn)備報數(shù)的
cout<<mend->data<<endl;
LinkList deletem=mend;
mend=pre->next;//mend指向報數(shù)的人;
free(deletem); //最后刪除
}
}
int main(){
Josephus(13,4,1);
return 0;
}
希望本文所述對大家的C++程序設(shè)計有所幫助。
欄 目:C語言
下一篇:C/C++中extern "C" 的作用分析
本文標(biāo)題:C++循環(huán)鏈表之約瑟夫環(huán)的實現(xiàn)方法
本文地址:http://m.jygsgssxh.com/a1/Cyuyan/3423.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10c++中inline的用法分析
- 01-10用C++實現(xiàn)DBSCAN聚類算法
- 01-10全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
- 01-10深入C/C++浮點數(shù)在內(nèi)存中的存儲方式詳解
- 01-10深入理解C/C++混合編程


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10C#中split用法實例總結(jié)
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05織夢dedecms什么時候用欄目交叉功能?


