【扫一扫了解最新限行尾号】
复制提示
C语言报数问题,报到3的人退出圈子,我快疯了
if(a[i] != 3)break;} printf(%d\n, i);return 0;} //妹子这很简单,就几步,用数组模拟学生数,给元素赋值,最后留一个不是3的就停止赋值循环,最后遍历一下把不是3的那个元素的下标加一输出,就完事了。
用数组模拟这n个人,用num来记他们的报数。当num=0时表示数组对应下标的人退出圈子,循环,最后留下来的人的号数就是数组中不为零的下标。
int flag[n]; //这个数组用来标记这个n个人的状态,一一对应,报过3的所对应的标记为1,否则0。所以初始化话时,flag里面都为0。
n=3时,留下1,2;n=4时,若只报数一轮,则剩下1,2,4;若报数两轮,则剩下首次报1,4的。n=5时,若只报数一轮,则剩下1,2,4,5;若报数两轮,则剩下首次报2,4的。
围成一个圈。但是,虽然被淘汰的人不再参与围成一个圈,但是,每次都要逐一判断这n人是否被淘汰,i就是用来记这个数的。所以,每次的圈子,表面上是由没有被淘汰的人围起来的,但是逐一进行了判断。希望对你有用。
...从第一个人开始报数(从1到3报数),凡报到3的人退出
先研究一些例子。n=3时,留下1,2;n=4时,若只报数一轮,则剩下1,2,4;若报数两轮,则剩下首次报1,4的。n=5时,若只报数一轮,则剩下1,2,4,5;若报数两轮,则剩下首次报2,4的。
每次不止退出一个人。因为是报到3的就退出。但是您只执行了n-- 应该是n-=(n+1)/3。或者是n=j。这样的话才是正确的。
又易知,最后剩下的人,在最后一轮的报数必然为1,那么可以利用同余式倒推其原始编号:(((1 + M)% 2 + M) % 3)+ M % 4。。
设有n个人(编号0~(n-1)),从0开始报数,报到(m-1)的退出,剩下的人继续从0开始报数 (用数学方法解的时候需要注意应当从0开始编号,因为取余会取到0解。
数组。先定义好一个足够长的数组,并初始化好数组的数据位(填入1~n),与上述类似,加个计数,当为3时把该数据置为一个特殊值(如0),表示已从该数组中删除。
int result[n]; //这个数组用来存放结果,为了一一对应,n个人里,第一个的序号是0,不是我们习惯采用的1。int flag[n]; //这个数组用来标记这个n个人的状态,一一对应,报过3的所对应的标记为1,否则0。
...从第1个人开始报数(从1到3),凡报到3的人退出圈子,问最后留
1、先研究一些例子。n=3时,留下1,2;n=4时,若只报数一轮,则剩下1,2,4;若报数两轮,则剩下首次报1,4的。n=5时,若只报数一轮,则剩下1,2,4,5;若报数两轮,则剩下首次报2,4的。
2、设有n个人(编号0~(n-1)),从0开始报数,报到(m-1)的退出,剩下的人继续从0开始报数 (用数学方法解的时候需要注意应当从0开始编号,因为取余会取到0解。
3、if(a[i] != 3)break;} printf(%d\n, i);return 0;} //妹子这很简单,就几步,用数组模拟学生数,给元素赋值,最后留一个不是3的就停止赋值循环,最后遍历一下把不是3的那个元素的下标加一输出,就完事了。
4、围成一个圈。但是,虽然被淘汰的人不再参与围成一个圈,但是,每次都要逐一判断这n人是否被淘汰,i就是用来记这个数的。所以,每次的圈子,表面上是由没有被淘汰的人围起来的,但是逐一进行了判断。希望对你有用。
5、设有n个人(编号0~(n-1)),从0开始报数,报到(m-1)的退出,剩下的人继续从0开始报数 (用数学方法解的时候需要注意应当从0开始编号,因为取余会取到0解。
报数游戏c语言报到3退出的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于c语言报数游戏是这样的,有n个人围成一圈、报数游戏c语言报到3退出的信息别忘了在本站进行查找喔。