约瑟夫环的队列实现

简介: 约瑟夫环的队列实现
//循环队列
//约瑟夫环
#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;
}
相关文章
|
3月前
|
机器学习/深度学习
约瑟夫环
【10月更文挑战第11天】
88 5
|
3月前
约瑟夫环问题
约瑟夫环
30 0
|
3月前
|
算法 Java
数据结构与算法学习六:单向环形链表应用实例的约瑟夫环问题
这篇文章通过单向环形链表的应用实例,详细讲解了约瑟夫环问题的解决方案,并提供了Java代码实现。
33 0
|
算法
约瑟夫环问题(三种方法)
约瑟夫环问题(三种方法)
157 0
|
Java
(五)Java数据结构之循环链表解决约瑟夫(Josephus)环问题
(五)Java数据结构之循环链表解决约瑟夫(Josephus)环问题
114 0
|
算法 索引 Python
细究“约瑟夫环”
细究“约瑟夫环”
103 0
|
JSON 算法 JavaScript
日拱算法:典例-快慢指针解“环形链表”
本篇带来一道基础但典型的体现快慢指针思路的算法题:环形链表 快慢指针是双指针的一种,用于判断链表是否有闭环,十分好用~ 冲ヾ(◍°∇°◍)ノ゙
|
算法 Java
算法 | 链表的应用,约瑟夫问题
算法 | 链表的应用,约瑟夫问题
141 0
算法 | 链表的应用,约瑟夫问题
|
Java 索引 Python
刷穿剑指offer-Day12-链表II 链表的环与交点
刷穿剑指offer-Day12-链表II 链表的环与交点
129 0