回答編集履歴

6

コード追記

2020/08/31 16:15

投稿

SHOMI
SHOMI

スコア4079

test CHANGED
@@ -65,3 +65,17 @@
65
65
  }
66
66
 
67
67
  ```
68
+
69
+
70
+
71
+ ---
72
+
73
+ `a == 0`の場合が考慮されていないのが原因なので、`modPow`の先頭に
74
+
75
+ ```C++
76
+
77
+ if (a == 0) return 1;
78
+
79
+ ```
80
+
81
+ を書けば再帰でも通ると思います。

5

文言修正

2020/08/31 16:15

投稿

SHOMI
SHOMI

スコア4079

test CHANGED
@@ -26,7 +26,7 @@
26
26
 
27
27
 
28
28
 
29
- [以前私が回答で貼った`modPow`](https://teratail.com/questions/286455#reply-406659)に差し替えて実行すると正解の`1`が返りますが、これでもだめですか?
29
+ [以前私が回答で貼った`modPow`](https://teratail.com/questions/286455#reply-406659)に差し替えて実行すると正解の`1`が返りますが、これでもだめですか?(提出しての確認はしていません)
30
30
 
31
31
  ```C++
32
32
 

4

文言修正

2020/08/31 15:40

投稿

SHOMI
SHOMI

スコア4079

test CHANGED
@@ -26,7 +26,7 @@
26
26
 
27
27
 
28
28
 
29
- [以前私が回答で貼った`modPow`](https://teratail.com/questions/286455#reply-406659)に差し替えて実行すると`1`が返りますが、これでもだめですか?
29
+ [以前私が回答で貼った`modPow`](https://teratail.com/questions/286455#reply-406659)に差し替えて実行すると正解の`1`が返りますが、これでもだめですか?
30
30
 
31
31
  ```C++
32
32
 

3

コード追記

2020/08/31 15:38

投稿

SHOMI
SHOMI

スコア4079

test CHANGED
@@ -17,3 +17,51 @@
17
17
  ```
18
18
 
19
19
  で`modPow(2, 0)`を無限に呼び続けています。
20
+
21
+
22
+
23
+ ---
24
+
25
+ > modPowという関数についてですが、この部分は別の機会で作ったものでこれまでも正しく動作していたので恐らく問題はないと思います。またこのmodPowとは別のアルゴリズムでべき乗計算を行うコードを提出しても同じケースでREとなりましたので
26
+
27
+
28
+
29
+ [以前私が回答で貼った`modPow`](https://teratail.com/questions/286455#reply-406659)に差し替えて実行すると`1`が返りますが、これでもだめですか?
30
+
31
+ ```C++
32
+
33
+ ll modPow(ll x, ll a)
34
+
35
+ {
36
+
37
+ long long ret = 1;
38
+
39
+ x %= MOD;
40
+
41
+ while (0 < a)
42
+
43
+ {
44
+
45
+ if (a % 2 == 0) {
46
+
47
+ x = (x * x) % MOD;
48
+
49
+ a /= 2;
50
+
51
+ }
52
+
53
+ else {
54
+
55
+ ret = (ret * x) % MOD;
56
+
57
+ --a;
58
+
59
+ }
60
+
61
+ }
62
+
63
+ return ret;
64
+
65
+ }
66
+
67
+ ```

2

コード追記

2020/08/31 15:38

投稿

SHOMI
SHOMI

スコア4079

test CHANGED
@@ -4,4 +4,16 @@
4
4
 
5
5
  `N`が`1`で`ans = modPow(2, N / 2);`を呼んでしまっているため、
6
6
 
7
+ ```C++
8
+
9
+ if (a % 2 == 0) {
10
+
11
+ ll t = modPow(x, a / 2);
12
+
13
+ return (t * t) % MOD;
14
+
15
+ }
16
+
17
+ ```
18
+
7
- `modPow(2, 0)`を無限に呼び続けています。
19
+ `modPow(2, 0)`を無限に呼び続けています。

1

リンク削除

2020/08/31 15:18

投稿

SHOMI
SHOMI

スコア4079

test CHANGED
@@ -1,6 +1,4 @@
1
- [提出 #16428925](https://atcoder.jp/contests/abc050/submissions/16428925)
2
-
3
- だとおもいますが、[REになっているケースの入力](https://www.dropbox.com/sh/arnpe0ef5wds8cv/AACiVu2IaOWRgMEWVrY78Sr4a/ARC066/C/in?preview=subtask_1_min_valid_01.txt)を入れてデバッガで追えば一発です。
1
+ [REになっているケースの入力](https://www.dropbox.com/sh/arnpe0ef5wds8cv/AACiVu2IaOWRgMEWVrY78Sr4a/ARC066/C/in?preview=subtask_1_min_valid_01.txt)を入れてデバッガで追えば一発です。
4
2
 
5
3
 
6
4