結果
問題 | No.2007 Arbitrary Mod (Easy) |
ユーザー | komisan19 |
提出日時 | 2022-08-17 18:25:28 |
言語 | Go (1.23.4) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 642 bytes |
コンパイル時間 | 10,589 ms |
コンパイル使用メモリ | 237,792 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-10-04 21:49:06 |
合計ジャッジ時間 | 13,359 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 30 |
ソースコード
package main import ( "bufio" "fmt" "os" "strconv" ) var sc = bufio.NewScanner(os.Stdin) var out = bufio.NewWriter(os.Stdout) const M = 998244353 func main() { buf := make([]byte, 1024*1024) sc.Buffer(buf, bufio.MaxScanTokenSize) sc.Split(bufio.ScanWords) defer out.Flush() a, n := nextInt(), nextInt() ans := pow(a, n, M) fmt.Fprintln(out, M) fmt.Fprintln(out, ans) } // nextInt int型で返す func nextInt() int { sc.Scan() i, _ := strconv.Atoi(sc.Text()) return i } // pow 累乗 func pow(a, b, m int) int { ret := 1 for b > 0 { if b%2 == 1 { ret = ret * a % m } b >>= 1 a = a * a % m } return ret }