约瑟夫环

 
   

N个人坐成一个圆环(编号为1 - N),从第1个人开始报数,数到K的人出列,后面的人重新从1开始报数。问最后剩下的人的编号。

例如:N = 3,K = 2。2号先出列,然后是1号,最后剩下的是3号。

Input

2个数N和K,表示N个人,数到K出列。(2 <=N, K <= 10^6)

Output
 
  

最后剩下的人的编号

Sample Input
 
  
3 2
Sample Output
 
  
3


 代码均为转载:http://blog.csdn.net/acdreamers/article/details/17686829

上面有见解。


其一代码如下:

#include<iostream>
#include<cstdio>

using namespace std;

int main()
{
    int t,n,k,i,p=1;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d%d",&n,&k);
        printf("Case #%d:",p++);
        printf(" %d %d",2*k,k);
        for(i=k-1;i>=1;i--)
            printf(" %d",i);
        for(i=k+1;i<=n;i++)
            if(i!=2*k)
                printf(" %d",i);
        puts("");
    }
    return 0;
}


其二代码如下:

#include <iostream>  
#include <string.h>  
#include <stdio.h>  
  
using namespace std;  
typedef long long LL;  
  
LL Work(LL n,LL m,LL k)  
{  
    if(m == 1)  
        k = (k == 1 ? n:(n+k-1)%n);  
    else  
    {  
        for(LL i=1; i<=n; i++)  
        {  
            if(k + m < i)  
            {  
                LL x = (i-k+1)/(m-1) - 1;  
                if(i + x < n)  
                {  
                    i += x;  
                    k += m*x;  
                }  
                else  
                {  
                    k += m*(n-i);  
                    i = n;  
                }  
            }  
            k = (k+m-1)%i+1;  
        }  
    }  
    return k;  
}  
  
int main()  
{  
    LL n,k;  
    while(cin>>n>>k)  
        cout<<Work(n,k,1)<<endl;;  
    return 0;  
} 

转载于:https://www.cnblogs.com/new-zjw/p/8540949.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值