And Then There Was One—-約瑟夫環

來源:互聯網
上載者:User

題目:http://poj.org/problem?id=3517

參考文章:約瑟夫環百度百科:http://baike.baidu.com/view/717633.htm

註:這裡的編號都是從0到n-1的。

n是總人數,k是報k的人出列,m-1是第一個出列的人,接著從m開始報數。

總的來說,就是遞推,將m-1出列後,轉化為n-1人,從0報數的情況。

原始碼:

#include <stdio.h>int n,k,m;int f;int main(){    freopen("D:\\a.txt","r",stdin);    while(1){    scanf("%d %d %d",&n,&k,&m);    if(!n&&!k&&!m)  break;    f=0;    for(int i=2;i<=n-1;i++)    f=(f+k)%i;    f=(f+m)%n;    printf("%d\n",f+1); }}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.