欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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)過問題,用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è)開始
 
 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)文章

最新評(píng)論