結果
| 問題 | No.141 魔法少女コバ | 
| コンテスト | |
| ユーザー |  kenkoooo | 
| 提出日時 | 2015-03-14 03:22:32 | 
| 言語 | Java (openjdk 23) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 52 ms / 5,000 ms | 
| コード長 | 1,116 bytes | 
| コンパイル時間 | 1,698 ms | 
| コンパイル使用メモリ | 77,196 KB | 
| 実行使用メモリ | 36,792 KB | 
| 最終ジャッジ日時 | 2024-06-28 22:53:15 | 
| 合計ジャッジ時間 | 8,244 ms | 
| ジャッジサーバーID (参考情報) | judge5 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 93 | 
ソースコード
import java.io.IOException;
public class Main {
	public static void main(String[] args) {
		int M = nextInt();
		int N = nextInt();
		int gcd = gcd(M, N);
		M /= gcd;
		N /= gcd;
		int magic = 0;
		while (N != M || N != 1) {
			if (M < N) {
				int tmp = M;
				M = N;
				N = tmp;
				magic++;
			} else if (M % N == 0) {
				int p = M / N;
				magic += p - 1;
				M = N;
			} else {
				int p = M / N;
				M %= N;
				magic += p;
			}
		}
		System.out.println(magic);
	}
	static int gcd(int a, int b) {
		// b=0ならaを最大公約数として終了
		if (b == 0) {
			return a;
		} else {
			// a÷bのあまりをb、元のbをaとして2.にもどる
			return gcd(b, a % b);
		}
	}
	static int nextInt() {
		int c;
		try {
			c = System.in.read();
			while (c != '-' && (c < '0' || c > '9'))
				c = System.in.read();
			if (c == '-')
				return -nextInt();
			int res = 0;
			while (c >= '0' && c <= '9') {
				res = res * 10 + c - '0';
				c = System.in.read();
			}
			return res;
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return -1;
	}
}
            
            
            
        