约瑟夫环的队列实现

简介: 约瑟夫环的队列实现
//循环队列
//约瑟夫环
#include<conio.h>
#include<stdio.h>
#include<iostream>
#define Size 10
using namespace std;
class Joseph{
private:
 int num[Size];//队列
 int first;//第一个人
 int top;//累加器上限
 int front;//队首
 int rear;//队尾
 int cnt;//累加器
public:
Joseph()
{
int i;
front = 0;
rear  = 0;
cnt   = 0;
for(i=0;i<Size;i++){
if((rear+1)%Size-front){
in(i);
}//if
}//for
}//Joseph()
void out()
{
front=(front+1)%Size;
}//out()
void in(int val)
{
      rear=(rear+1)%Size;
  num[rear]=val;
}//in()
 void JosephRoll()
{
cout<<"Please input the first number:";
        scanf("%d",&first);
cout<<"Please input the next number:";
scanf("%d",&top);
while(num[(front+1)%Size]-first){
            out();
in(num[front]);
cout<<num[front]<<endl;
}//while
while(rear-front){
cnt=0;
while(cnt-top){
out();
in(num[front]);
cnt++;
}//while(cnt-top-2)
out();
cout<<"num:"<<num[front]<<endl;
}//while(rear-front)
}
};
int main(void)
{
Joseph Roll1;
Roll1.JosephRoll();
return 0;
}
相关文章
|
1月前
|
机器学习/深度学习
约瑟夫环
【10月更文挑战第11天】
56 5
|
1月前
约瑟夫环问题
约瑟夫环
23 0
|
存储 算法
力扣环形链表(1)进阶环形链表(2)及环形链表的约瑟夫问题
力扣环形链表(1)进阶环形链表(2)及环形链表的约瑟夫问题
52 0
|
算法
约瑟夫环问题(三种方法)
约瑟夫环问题(三种方法)
141 0
|
Java
(五)Java数据结构之循环链表解决约瑟夫(Josephus)环问题
(五)Java数据结构之循环链表解决约瑟夫(Josephus)环问题
104 0
|
算法 索引 Python
细究“约瑟夫环”
细究“约瑟夫环”
96 0
|
算法
单向环形链表介绍以及约瑟夫问题分析
单向环形链表介绍以及约瑟夫问题分析
135 0
|
算法
单向环形链表解决Josephu(约瑟夫)问题
单向环形链表解决Josephu(约瑟夫)问题
110 0
单向环形链表解决Josephu(约瑟夫)问题
|
索引
【Leetcode】拿捏链表(四)——160. 相交链表、141. 环形链表、142. 环形链表 II(二)
【Leetcode】拿捏链表(四)——160. 相交链表、141. 环形链表、142. 环形链表 II(二)
107 0
【Leetcode】拿捏链表(四)——160. 相交链表、141. 环形链表、142. 环形链表 II(二)