约瑟夫环的队列实现

简介: 约瑟夫环的队列实现
//循环队列
//约瑟夫环
#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;
}
相关文章
|
10月前
|
存储 算法
|
7月前
|
算法
约瑟夫环问题(三种方法)
约瑟夫环问题(三种方法)
94 0
|
10月前
|
Java
(五)Java数据结构之循环链表解决约瑟夫(Josephus)环问题
(五)Java数据结构之循环链表解决约瑟夫(Josephus)环问题
65 0
|
11月前
|
算法 索引 Python
细究“约瑟夫环”
细究“约瑟夫环”
77 0
|
12月前
|
算法
单向环形链表介绍以及约瑟夫问题分析
单向环形链表介绍以及约瑟夫问题分析
92 0
|
12月前
约瑟夫环问题
使用queue<int>q记得加上头文件#include<queue>
55 0
|
算法
单向环形链表解决Josephu(约瑟夫)问题
单向环形链表解决Josephu(约瑟夫)问题
78 0
单向环形链表解决Josephu(约瑟夫)问题
约瑟夫环
题目: 已知n个人(以编号1,2,3--n分别表示)围坐在一张圆桌周围。从编号为1的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人有出列;以此规律重复下去,知道圆桌周围的人全部出列。输出出列顺序和最后剩下的人。
74 0
|
算法 Java
算法 | 链表的应用,约瑟夫问题
算法 | 链表的应用,约瑟夫问题
100 0
算法 | 链表的应用,约瑟夫问题