sicily 猴子选大王
题目描述
猴子选大王,有N只猴子,从1~N进行编号。它们按照编号的顺时针方向,排成一个圆圈,然后从第一只猴子开始报数。第一只猴子报1,以后每只猴子报的数字都是它前面猴子所报数字加1。如果一只猴子报的数字是M,则该猴子出列,下一只猴子重新从1开始报数。剩下的猴子继续排成一个圆圈报数,直到全部的猴子都出列为止。最后一个出列的猴子胜出。
输入格式
The first line is an integer t, indicating the number of test cases. Then there are t lines and each line contains two positive integer N(0<N<=100) and M(0<M<=100).
For each test case, print out the number of the Monkey King.
2
5 2
4 3
3
1
--------------------------我不是分割线-------------------------------------------------------------- 分析:开始时并没有考虑太多,就选择了用struct的数组来简单实现,不过时间上耗费略大
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std; struct data
{
int count;
bool is;
}; int cmp(data a[],int n){
int count1=,out;
for (int i = ; i < n; ++i)
{
if (a[i].is==)
{
++count1;
out=a[i].count;
}
}
if (count1==)
{
return out;
}
else{
return ;
}
}
int main(int argc, char const *argv[])
{
int t;
cin>>t;
for (int i = ; i < t; ++i){
int m,n;
cin>>m>>n;
data monkey[m];
for (int i = ; i <m; ++i)
{
monkey[i].count=i+;
monkey[i].is=;
}
int ji=;int count2=;int i=;
int isf=cmp(monkey,m);
while(!isf){
if (monkey[i].is==)
{
++count2;
if (count2==n)
{
monkey[i].is=;
count2=;
}
}
++i;
if(i==m){
i=;/*实现循环,保证由count2来决定循环撤出的有效性*/
}
isf=cmp(monkey,m);
}
cout<<isf<<endl;
}
return ;
}
sicily 猴子选大王的更多相关文章
- POJ3750: 小孩报数问题+一道经典约瑟夫问题(猴子选大王)
		
又一次因为一个小错误,POJ上Wrong Answer了无数次..... 在差不多要放弃的时候,发现了这个猥琐的不能再猥琐的bug,改完了提交就AC了,简直无语.... 本题wo采用模拟方法: 1 # ...
 - PHP编程----猴子选大王
		
<?php/** * 猴子选大王 * 17个猴子围成一圈,从某个开始报数1-2-3-1-2-3---报"3"的猴子就被淘汰, * 游戏一直进行到圈内只剩一只猴子它就是猴大王了 ...
 - 猴子选大王 (约瑟夫环)(c#)
		
猴子选大王问题: 一堆猴子都有编号,编号是1,2,3 ...m ,这群猴子(m个)按照1到m的顺序围坐一圈, 从第1开始数,每数到第n个,该猴子就要离开此圈,这样依次下来,直到圈中只剩下最后一只猴子, ...
 - PHP洗牌、猴子选大王两个小算法
		
<一>洗牌算法 /** *洗牌算法washCard *@param $cardNum *@return array */ function washCard($cardNum) { $ca ...
 - 猴子选大王的c#实现
		
原文地址:猴子选大王的c#实现作者:余文 今天被问到了猴子选大王的意思,题目大意就是说有n只猴子围坐成一个圈,按顺时针方向从1到n编号.然后从1号猴子开始沿顺时针方向从1开始报数,报到m的猴子出局,再 ...
 - 猴子选大王【PHP】
		
目录 猴子选大王 指针解决 数组压栈 猴子选大王 一群猴子排成一圈,按1,2,...,n依次编号.然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去...,如此不 ...
 - C语言程序设计-猴子选大王[链表应用]
		
2032 猴子选大王 Description 有N只猴子,从1~N进行编号.它们按照编号的顺时针方向排成一个圆圈,然后从第一只猴子开始报数.第一只猴子报的第一个数字为1,以后每只猴子报的数字都是它们前 ...
 - 约瑟夫环问题(猴子选大王)PHP版
		
约瑟夫斯问题问题有时候也被描述成猴子选大王问题,题目如下.(最后会贴上约瑟夫问题的来历) 一群猴子排成一圈,按1,2,…,n依次编号. 然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再 ...
 - SYCOJ27猴子选大王
		
题目-猴子选大王 (shiyancang.cn) 一.出队顺序Description有M个人,其编号分别为1-M.这M个人按顺序排成一个圈.现在给定一个数N,从第一个人开始依次报数,数到N的人出列,然 ...
 
随机推荐
- No.008:String to Integer (atoi)
			
问题: Implement atoi to convert a string to an integer. Hint: Carefully consider all possible input ca ...
 - CSS Hack解决浏览器IE部分属性兼容性问题
			
1.Css Hack 不同厂商的流览器或某浏览器的不同版本(如IE6-IE11,Firefox/Safari/Opera/Chrome等),对CSS的支持.解析不一样,导致在不同浏览器的环境中呈现出不 ...
 - 简单实用的二级树形菜单hovertree
			
原创 hovertree是一个仿京东的树形菜单jquery插件,暂时有银色和绿色两种. 官方网址:http://keleyi.com/jq/hovertree/欢迎下载使用 查看绿色效果:http:/ ...
 - 中文字体font-family常用列表
			
Windows的一些: 黑体:SimHei 宋体:SimSun 新宋体:NSimSun 仿宋:FangSong 楷体:KaiTi 仿宋_GB2312:FangSong_GB2312 楷体_GB2312 ...
 - iOS 线程间的通信 (GCD)
			
1.从网络上 下载一张图片将它显示在view上 - (void)imageDownload { dispatch_async(dispatch_get_global_queue(DISPATCH_QU ...
 - Atitit.去除水印的方案
			
Atitit.去除水印的方案 1.1. 查找水印的位置 Kegwa imgd posit zo ok le .. Auto find d zo troub ...manu easy 1.2. 还原去除 ...
 - ios中@class和 #import区别
			
很多刚开始学习iOS开发的同学可能在看别人的代码的时候会发现有部分#import操作写在m文件中,而h文件仅仅使用@class进行声明,不禁纳闷起来,为什么不直接把#import放到h文件中呢?这是因 ...
 - Android measure过程分析
			
作为一名Android开发人员,我们都知道一个View从无到有,会经历3个阶段: 1. measure/测量阶段,也就是确定某个view大小的过程: 2. layout/布局阶段,也就是确定其左上右下 ...
 - iOS--UIAlertView与UIAlertController和UIAlertAction之间的事儿
			
iOS 8的新特性之一就是让接口更有适应性.更灵活,因此许多视图控制器的实现方式发生了巨大的变化.全新的UIPresentationController在实现视图控制器间的过渡动画效果和自适应设备 ...
 - 开源代码:Http请求封装类库HttpLib介绍、使用说明
			
今天介绍一个很好用的Http请求类库--Httplib.一直以来,我们都是为了一次web请求,单独写一段代码 有了这个类,我们就可以很方便的直接使用了. 项目介绍: http://www.suchso ...