C语言:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报 数),凡报到3的人退出圈子 问最后留下#includestid-i(void){main(){while(1){int n,i,a[100],k=0,b[100];for(i=1;i

来源:学生作业帮助网 编辑:作业帮 时间:2024/05/02 17:58:59
C语言:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报 数),凡报到3的人退出圈子 问最后留下#includestid-i(void){main(){while(1){int n,i,a[100],k=0,b[100];for(i=1;i

C语言:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报 数),凡报到3的人退出圈子 问最后留下#includestid-i(void){main(){while(1){int n,i,a[100],k=0,b[100];for(i=1;i
C语言:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报 数),凡报到3的人退出圈子 问最后留下
#include
stid-i(void)
{
main()
{
while(1){int n,i,a[100],k=0,b[100];
for(i=1;i

C语言:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报 数),凡报到3的人退出圈子 问最后留下#includestid-i(void){main(){while(1){int n,i,a[100],k=0,b[100];for(i=1;i
这样做可以,不过时间复杂度不太好,为O(n ^ 2).
事实上,约瑟夫问题存在着时间复杂度为O(n)的解法.
要解决这个问题,要用到同余这个数学工具.
下面,假设目前还剩下K个人,这K个人从1到M报数,那么,当第M个人被杀后,剩下的人将按照怎样的规则报数呢?
如果我们将第M个人被杀后,第P个人报的数计做Q,那么可以得到下面的同余式:
(P - M % K) % K = Q
将上式变形可以得出:
P = ( Q + M)% K
那么可以知道,在第(N - K + 2)轮报数为Q的人,在第(N - K + 1)轮的报数为 ( Q + M)% K.
又易知,最后剩下的人,在最后一轮的报数必然为1,那么可以利用同余式倒推其原始编号:
(((1 + M)% 2 + M) % 3)+ M % 4.
变成程序为:
#include
using namespace std;
const int M = 3;
int main(){
int n,i,ind;
printf("please input a number:");
scanf("%d",&n);
ind = 1;
for( i = 2; i

c语言:有n个人围成一圈,顺序排号.从第一个人开始报数(从1~3报数),报到3的人退出圈子,求退出顺序 C语言指针 有n个人围城一圈,顺序排号.从第一个人开始报数(从1报到3),凡报到3的人有n个人围城一圈,顺序排号.从第一个人开始报数(从1报到3),凡报到3 的人退出圈子,问最后留下的是原来的第几 有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报数),凡报到3的人退出n为50 C语言:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报 数),凡报到3的人退出圈子 问最后留下#includestid-i(void){main(){while(1){int n,i,a[100],k=0,b[100];for(i=1;i 有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报数),凡报到3的人退出(pascal有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报数),凡报到3的人退出 圈子,问最后留下的是原来 2:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,请输出报数出 C语言:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报 数),凡报到3的人退出圈子问最后留下的是原来的第几号.(不要用指针.指针还不懂.) 用C语言编写:有n个人围成一圈,顺序排号.从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,请输出报数出列圈及最后留下的数据和在原来位置的第几号. 有n个人围成一圈,顺序排号从第1个人开始报数(丛1到3报数)凡报到3的人退出圈子最后留下的是原来第几号请用一个C的程序解,并且必须用到指针 C语言:有n人围成一圈,顺序排号.从第1个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来的第几号的那位. (直接要答案,谢谢) C语言:有n个人围成一圈,按顺序从1到n编号.从第一个人开始报数,报数3的人退出圈子【问题描述】 有n个人围成一圈,按顺序从1到n编号.从第一个人开始报数,报数3的人退出圈子,下一个人从1开 C语言 有n个人围成一圈,按顺序从1到n编号.从第一个人开始报数,报数3的人退出圈子有n个人围成一圈,按顺序从1到n编号.从第一个人开始报数,报数3的人退出圈子,下一个人从1开始重新报数,报数 有n个人围成一圈,按顺序从1到n编号.从第一个人开始报数,报数3的人退出圈子,下一个人从1开始重新报数,用最简单的C语言, c语言:有n个人围成一圈,按顺序编号.从第1个人开始报数,数到m时该人退出,并且下一个从1重新开始报数.如题 要求按顺序输出退出的人的编号 这是我写的#include stdafx.h#include stdio.hvoid delete1 、用指针完成下面程序:有n个人围成一圈,顺序排号,从第一个人开始报数(从1-3报数),凡报到3的退出圈子,请编程求出最后留下的是原来的第几号的那位. 有N个人围成一圈,顺序排号.从第一个人开始报号,(1-3报号)报到3的退出,问最后剩下的是几号?求大神帮忙看下哪个地方有错,我试了只有m=1的时候能输出10;其他的都没有输出.#includeusing namesp 三道C语言题目,求大神(用指针的方法).1.有n个人围成一圈,按顺序从1到n编号.从第一个人开始报数,报数3的人退出圈子,下一个人从1开始重新报数,报数3的人退出圈子.如此循环,直到留下最后 有10个人围成一圈,顺序排号.从第一个人开始报数(从1到3报数),凡报到了的人退出圈子,问最后留下的是原来第几号的那位.(请写一个函数来计算)