当前位置: 首页 > news >正文

东方博易oj——3119 - 约瑟夫问题2(链表)

文章目录

  • 题目
    • 题目描述
    • 输入
    • 输出
    • 样例
      • 输入
    • 输出
    • 标签
  • AC代码


题目

题目描述

约瑟夫问题:有 n n 只猴子,按顺时针方向围成一圈选大王(编号从 1 1 n n ),从第 1 1 号开始报数,一直数到 m m ,数到 m m 的猴子退出圈外,剩下的猴子再接着从 1 1 1开始报数。

就这样,直到圈内只剩下一只猴子时,这个猴子就是猴王,编程求输入 n,m n,m n,m后,输出最后猴王的编号。

输入

每行是用空格分开的两个整数,第一个是 n n n, 第二个是 m ( 0 < m , n < = 300 ) m (0 < m,n <=300) m(0<m,n<=300)

最后一行是:0 0

输出

对于每行输入数据(最后一行除外),输出数据也是一行,即最后猴王的编号。

样例

输入

6 2
12 4
8 3
0 0

输出

5
1
7

标签

链表

AC代码

#include<bits/stdc++.h>
using namespace std;
void ysf(int n,int m) {int llist[10005],id,i,j;for(i=0; i<n; i++)	{llist[i]=i+1;	}llist[n]=1;for(i=1; i<=n; i++) {j=1;while(j<m) {id=llist[id],j++;	}llist[id]=llist[llist[id]];}cout<<llist[id]<<endl;
}
int main() {int n=1,m=1;while(n!=0&&m!=0) {cin>>n>>m;if(n==0&&m==0)break; ysf(n,m);}return 0;
}
http://www.lryc.cn/news/158900.html

相关文章:

  • C++,day0907
  • 孤儿僵尸守护进程的简单理解
  • 学习笔记——Java入门第一季
  • 更改注册表exe值后的惨痛经历
  • stable diffusion实践操作-LyCORIS
  • 无需公网IP教你如何外网远程访问管家婆ERP进销存
  • Swift使用编解码库Codable
  • Vue + Element UI 前端篇(三):工具模块封装
  • 【pytorch】数据加载dataset和dataloader的使用
  • 搭建单机版FastDFS分布式文件存储系统
  • 【验证码逆向专栏】房某下登录滑块逆向分析
  • Python 3.11 版本是对线程安全做了什么更改吗
  • 【Docker】镜像的创建、管理与发布
  • 移动硬盘或U盘无法弹出的解决方法
  • (leetcode1761一个图中连通三元组的最小度数,暴力+剪枝)-------------------Java实现
  • 【漏洞复现】金和OA C6任意文件读取漏洞
  • 2023年全国大学生数学建模B题
  • 【LeetCode】2651.计算列车到站时间
  • Redis——认识Redis
  • 通讯录怎么导入新手机?3个推荐小妙招
  • Geoserver发布shp、tiff、瓦片等格式的GIS数据
  • 读书笔记-《ON JAVA 中文版》-摘要24[第二十一章 数组]
  • go语言基本操作---五
  • 【sgLazyTree】自定义组件:动态懒加载el-tree树节点数据,实现增删改、懒加载及局部数据刷新。
  • Rust个人学习笔记
  • Java根据身份证号码提取出省市区,JSON数据格式
  • MySQL知识笔记——初级基础(实施工程师和DBA工作笔记)
  • javaee 事务的传播行为
  • C#-SQLite-使用教程笔记
  • Tomcat详解 一:tomcat的部署