結果
| 問題 |
No.167 N^M mod 10
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2016-09-07 01:05:59 |
| 言語 | Go (1.23.4) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 545 bytes |
| コンパイル時間 | 15,936 ms |
| コンパイル使用メモリ | 219,136 KB |
| 実行使用メモリ | 6,816 KB |
| 最終ジャッジ日時 | 2024-11-15 21:02:13 |
| 合計ジャッジ時間 | 16,996 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 WA * 1 |
| other | AC * 13 WA * 14 |
ソースコード
package main
import (
"fmt"
"math/big"
)
func pow(x, y *big.Int) int{
x = x.Mod(x, big.NewInt(10))
xx := int(x.Uint64())
zero := big.NewInt(0)
z := 1
for ; y.Cmp(zero) != 0 ; {
if y.Bit(0) == 1 {
z = z * xx % 10
}
xx = xx * xx % 10
y = y.Rsh(y, 1)
}
return z
}
func main() {
var sx, sy string
fmt.Scanf("%s%s",&sx, &sy)
x := big.NewInt(1)
y := big.NewInt(1)
x.SetString(sx, 10)
y.SetString(sy, 10)
z := pow(x, y)
fmt.Println(z)
}