POJ 1012 Joseph

原创 2018年04月15日 13:46:38

Description

The Joseph's problem is notoriously known. For those who are not familiar with the original problem: from among n people, numbered 1, 2, . . ., n, standing in circle every mth is going to be executed and only the life of the last remaining person will be saved. Joseph was smart enough to choose the position of the last remaining person, thus saving his life to give us the message about the incident. For example when n = 6 and m = 5 then the people will be executed in the order 5, 4, 6, 2, 3 and 1 will be saved. 

Suppose that there are k good guys and k bad guys. In the circle the first k are good guys and the last k bad guys. You have to determine such minimal m that all the bad guys will be executed before the first good guy.

Input

The input file consists of separate lines containing k. The last line in the input file contains 0. You can suppose that 0 < k < 14.

Output

The output file will consist of separate lines containing m corresponding to k in the input file.

translation

约瑟夫问题:n个人围着坐,编号为1~n,从第一个人开始报数,报到第m个数的人被杀死,然后从下一个人接着开始报数,直到只剩下一个人。

例如:n=6,m=5时,出局的顺序为5, 4, 6, 2, 3,1幸运的活了下来。

题目假设一共有2*k个人,前k个为好人,后k个为坏人,要求求出 先出局的k个人 全部为坏人的 最小m。

记得打表,不打表会超时。

这个题目枚举完全可以AC,我看评论区有的人算出来k=1~13时的对应的m,然后直接打印输出。

/*
author:wangqi
url:http://poj.org/problem?id=1012
代码中的字母和题目中的意义一样
思路:人围坐一圈下标为:0-2*k-1;(这样不需要把0换成2*k),注意这里和题目的编号不一样;
从第一次报数开始,用num来记录上一次报数的人的下标
拿k=3,m=5举例   
下标变化为:(0,1,2,3,4,5) -> (0,1,2,3,4) -> (0,1,2,3) -> (0,1,2,3)
删除的人为:删除下标为m-1=4的人,4~5的人变为3~4; 
            删除下标为(4+5-1)%5=3的人,4~4的人变为3~3;
            删除下标为(3+5-1)%4=3的人,此时坏人全部删除。
*/
#include<iostream>
using namespace std;
int main(){
    int m,k,i,result[15] = {0}; //result数组用于打表,猜测有很多重复的
    while(cin>>k && k!= 0){
            if(result[k] != 0){
                cout<<result[k]<<endl;
                continue;
            }
            for(m = k+1;;m++){
                int num = 0;
                for(i = 0 ; i < k; i++){
                    num = (num + m -1)%(2*k-i); //下标
                    if(num < k){ //num<k表示在全部坏人未删除完之前,删除了好人
                        break;
                    }
                }
                if(i == k){
                    cout<<m<<endl;
                    break;
                }
            }
            result[k] = m;
    }
}

POJ-1012 Joseph-约瑟夫问题好人坏人

Joseph Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 50354   Accepted: 19143 ...
  • MIKASA3
  • MIKASA3
  • 2015-08-25 16:47:52
  • 1031

POJ1012Joseph解题报告

约瑟夫环 POJ 1012 Joseph解题报告
  • Dafang_Xu
  • Dafang_Xu
  • 2015-10-22 21:19:17
  • 1182

POJ-1012-Joseph-暴力/模拟

约瑟夫问题 前k个好人和后k个坏人排在一起 要求先删除全部坏人才能删除好人 暴力vector模拟一下。。打表交。。 int ans[15]={-1,2,7,5,30,169...
  • viphong
  • viphong
  • 2015-11-10 18:45:57
  • 195

poj 1012解题报告

  • 2010年04月02日 13:22
  • 3KB
  • 下载

约瑟夫环问题 poj 1012 && poj 2244

百度百科:http://baike.baidu.com/link?url=msOmvPMbbYAhxiaRjsBLi1WRRFL1WuDXZXdlrQE-vOvnslpORlOP_4_hgNWgH5D...
  • u012349696
  • u012349696
  • 2015-07-13 13:58:12
  • 498

北大ACM试题1012-约瑟夫环

简直就是悲伤中的战斗机。。。居然又是两个月没更新了。。原因是搬新家而且老婆孩子来了,具体啥原因真心是一言难尽。。。但是真的感觉有了家庭就很难提起劲来学习了。。。每天也没干啥就过去了。。。这样不行。。。...
  • heroskaka
  • heroskaka
  • 2015-09-07 22:23:38
  • 573

ACM_CUGOJ_1012_Joseph Problem约瑟夫

Home Web Board ProblemSet Standing Status Statistics 阅读,思考,分享,K题。编程优化人生! Problem B...
  • wordsin
  • wordsin
  • 2016-07-16 00:32:17
  • 301

POJ 1012

POJ 1012JosephTime Limit: 1000MS  Memory Limit: 10000K Total Submissions: 16275  Accepted: 6040 Desc...
  • ericxieforever
  • ericxieforever
  • 2008-04-27 19:17:00
  • 3773

POJ 1012(Joseph)

POJ 1012(Joseph)
  • Ema1997
  • Ema1997
  • 2016-04-10 17:34:15
  • 172

POJ 1012 Joseph

Language:                                                                                           ...
  • zp___waj
  • zp___waj
  • 2015-08-19 09:17:41
  • 572
收藏助手
不良信息举报
您举报文章:POJ 1012 Joseph
举报原因:
原因补充:

(最多只允许输入30个字)