1012 Joseph

1012 Joseph

解答例

import java.util.*;
public class Main {
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner sc = new Scanner(System.in);
        int ans[] = new int[14];
        ans[0] = -1;
        for(int i=1;i<14;i++){
            int c = 1;
            while(true){
                if(proper(i, c)){
                    ans[i] = c;
                    break;
                }
                else{
                    c++;
                }
            }
        }
        
        while(true){
            int x = sc.nextInt();
            if(x==0) break;
            System.out.println(ans[x]);
        }
    }
    private static boolean proper (int k, int m){
        int x = 0;
        for(int i=0;i<k;i++){
            x = (x + m - 1) % (2*k-i);
            if(x<k) return false;
        }
        return true;
    }
}

タグ:

+ タグ編集
  • タグ:

このサイトはreCAPTCHAによって保護されており、Googleの プライバシーポリシー利用規約 が適用されます。

最終更新:2006年05月13日 18:29
ツールボックス

下から選んでください:

新しいページを作成する
ヘルプ / FAQ もご覧ください。