結果

問題 No.2 素因数ゲーム
ユーザー scalerscaler
提出日時 2024-08-31 15:20:41
言語 Scala(Beta)
(3.4.0)
結果
AC  
実行時間 1,099 ms / 5,000 ms
コード長 617 bytes
コンパイル時間 12,037 ms
コンパイル使用メモリ 258,392 KB
実行使用メモリ 65,356 KB
最終ジャッジ日時 2024-08-31 15:21:24
合計ジャッジ時間 42,495 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 888 ms
64,980 KB
testcase_01 AC 933 ms
65,012 KB
testcase_02 AC 927 ms
65,028 KB
testcase_03 AC 928 ms
65,068 KB
testcase_04 AC 908 ms
65,084 KB
testcase_05 AC 928 ms
65,124 KB
testcase_06 AC 949 ms
65,052 KB
testcase_07 AC 938 ms
65,124 KB
testcase_08 AC 925 ms
65,160 KB
testcase_09 AC 931 ms
65,160 KB
testcase_10 AC 932 ms
65,144 KB
testcase_11 AC 926 ms
64,936 KB
testcase_12 AC 897 ms
64,968 KB
testcase_13 AC 895 ms
65,164 KB
testcase_14 AC 926 ms
65,192 KB
testcase_15 AC 928 ms
65,060 KB
testcase_16 AC 894 ms
65,120 KB
testcase_17 AC 919 ms
65,048 KB
testcase_18 AC 921 ms
64,944 KB
testcase_19 AC 1,037 ms
65,176 KB
testcase_20 AC 986 ms
65,004 KB
testcase_21 AC 1,099 ms
65,104 KB
testcase_22 AC 912 ms
65,052 KB
testcase_23 AC 928 ms
65,052 KB
testcase_24 AC 930 ms
64,872 KB
testcase_25 AC 908 ms
65,356 KB
testcase_26 AC 931 ms
64,996 KB
testcase_27 AC 921 ms
65,140 KB
testcase_28 AC 925 ms
65,140 KB
testcase_29 AC 899 ms
65,004 KB
testcase_30 AC 915 ms
65,156 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

import scala.io.StdIn.readLine
import scala.collection.mutable.Map

@main
def yuki2(): Unit =
  val n = readLine.toInt
  val factorsMap = primeFactorization(n)
  var ret: Int = 0
  for (_, v) <- factorsMap do ret ^= v
  println(if ret == 0 then "Bob" else "Alice")

def primeFactorization(n: Int): Map[Int, Int] =
  val factors = Map[Int, Int]()
  var num = n
  while num % 2 == 0 do
    factors(2) = factors.getOrElse(2, 0) + 1
    num /= 2
  var divisor = 3
  while num > 1 do
    while num % divisor == 0 do
      factors(divisor) = factors.getOrElse(divisor, 0) + 1
      num /= divisor
    divisor += 2
  factors
0