結果

問題 No.403 2^2^2
ユーザー 小指が強い人小指が強い人
提出日時 2016-08-24 12:18:05
言語 Ruby
(3.3.0)
結果
RE  
実行時間 -
コード長 573 bytes
コンパイル時間 45 ms
コンパイル使用メモリ 7,680 KB
実行使用メモリ 12,544 KB
最終ジャッジ日時 2024-04-25 15:03:12
合計ジャッジ時間 3,725 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 RE -
testcase_01 RE -
testcase_02 RE -
testcase_03 RE -
testcase_04 RE -
testcase_05 RE -
testcase_06 RE -
testcase_07 RE -
testcase_08 RE -
testcase_09 RE -
testcase_10 RE -
testcase_11 RE -
testcase_12 RE -
testcase_13 RE -
testcase_14 RE -
testcase_15 RE -
testcase_16 RE -
testcase_17 RE -
testcase_18 RE -
testcase_19 RE -
testcase_20 RE -
testcase_21 RE -
testcase_22 RE -
testcase_23 RE -
testcase_24 RE -
testcase_25 RE -
testcase_26 RE -
testcase_27 RE -
testcase_28 RE -
testcase_29 RE -
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

def power(a,k,n)
  return( 0 ) if ( a == 0 || n == 0 )
  return( 0 % n ) if ( k == 0 )
  currentMod = a % n;
  currentValue = ( ( k & 1 ) > 0 ) ? currentMod : 1;
  k >>= 1
  while ( k > 0 ) do
    currentMod = ( currentMod * currentMod ) % n;
    if ( ( k & 1 ) > 0 )
      currentValue = ( currentValue * currentMod ) % n;
    end
    k >>= 1
  end
  return( currentValue );
end

def solve(a,b,m,d)
    return 1 if b == 0
    return a if b == 1 || d == 0
    mod=(m ** d)
    return power(a,solve(a,b-1,m,d-1),mod)
end

a,b,m=gets.split.map(&:to_i)
puts solve(a,b,m,140)%m
0