约瑟夫环

简介: 题目:已知n个人(以编号1,2,3--n分别表示)围坐在一张圆桌周围。从编号为1的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人有出列;以此规律重复下去,知道圆桌周围的人全部出列。输出出列顺序和最后剩下的人。

题目:

已知n个人(以编号1,2,3--n分别表示)围坐在一张圆桌周围。从编号为1的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人有出列;以此规律重复下去,知道圆桌周围的人全部出列。输出出列顺序和最后剩下的人。

分析:

这道题用我们平常的数组也能做,只不过要用到那个取模,

上代码:

#include <iostream>

using namespace std;

int main(void)

{

int n,p=0,m,k=0;
cin>>n>>m;
int arr[n];
for(int i=0;i<n;i++)
{
    arr[i]=i+1;
}
while(n>1)
{
    p=(p+m-1)%n;
cout<<++k<<" "<<arr[p]<<endl;
for(int j=p+1;j<n;j++)
    {
        arr[j-1]=arr[j];
    }
    n--;
if(p==n) p=0;
}
cout<<"最后剩下的是"<<arr[p]<<endl;
return 0;

}

目录
相关文章
|
3月前
|
机器学习/深度学习
约瑟夫环
【10月更文挑战第11天】
87 5
|
3月前
约瑟夫环问题
约瑟夫环
30 0
约瑟夫环问题的几种解法
约瑟夫环问题的几种解法
113 0
|
算法
约瑟夫环问题(三种方法)
约瑟夫环问题(三种方法)
156 0
|
Java
(五)Java数据结构之循环链表解决约瑟夫(Josephus)环问题
(五)Java数据结构之循环链表解决约瑟夫(Josephus)环问题
114 0
|
算法 索引 Python
细究“约瑟夫环”
细究“约瑟夫环”
103 0
约瑟夫环的解法
约瑟夫环的解法
131 0
|
Java
约瑟夫环问题Java实现
约瑟夫环(约瑟夫问题)是一个数学的应用问题:已知 n 个人(以编号1,2,3…n分别表示)围坐在一张圆桌周围。从编号为 k 的人开始报数,数到 m 的那个人出圈;他的下一个人又从 1 开始报数,数到 m 的那个人又出圈;依此规律重复下去,直到剩余最后一个胜利者。
124 0

热门文章

最新文章

下一篇
开通oss服务