当前位置:首页 » 编程语言 » c语言约瑟夫环问题

c语言约瑟夫环问题

发布时间: 2024-04-23 10:21:34

A. 将自然数1至100按顺时针围成一圈,首先取出1,然后顺时针方向按步长L=30取数(已取出的数不再参加计数),

这其实就是一个约瑟夫环问题,你网络一下就知道了
类似于已知100个人(以编号1,2,3...100分别表示)围坐在一张圆桌周围。从编号为1的人开始报数,数到30的那个人出列;他的下一个人又从1开始报数,数到30的那个人又出列;依此规律重复下去,直到圆桌周围只剩下一个人,求这个人的编号。
数组实现
#include<iostream.h>
int main()
{
const int n=100;
int m=30;
int a[n];

for(int j=0;j<n;j++)
a[j]=j+1;
int k=1;
int i=-1;

while(1)
{

for(int j=0;j<m;)
{
i=(i+1)%n;
if(a[i]!=0)
j++;
}
if(k==n)
break;
a[i]=0;
k++;
}
cout<<a[i]<<endl;
return 0;
}

(用单向链表,双向链表实现见我的空间)

热点内容
算法和人性 发布:2025-01-20 03:28:31 浏览:473
软件编程1级 发布:2025-01-20 03:19:39 浏览:952
嫁个编程男 发布:2025-01-20 02:51:39 浏览:933
挂劳文件夹 发布:2025-01-20 02:44:22 浏览:521
写编程英文 发布:2025-01-20 02:37:50 浏览:16
安卓怎么修改饥荒 发布:2025-01-20 02:20:54 浏览:619
android64位开发环境 发布:2025-01-20 01:58:01 浏览:262
阿里云服务器能搭美国站点 发布:2025-01-20 01:49:34 浏览:278
安卓手机壁纸如何更换成动态壁纸 发布:2025-01-20 01:40:27 浏览:706
安卓微信签名在哪里修改 发布:2025-01-20 01:25:31 浏览:110