結果
問題 | No.10 +か×か |
ユーザー | Kodai |
提出日時 | 2020-04-16 20:25:16 |
言語 | Python3 (3.12.2 + numpy 1.26.4 + scipy 1.12.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 733 bytes |
コンパイル時間 | 97 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 13,632 KB |
最終ジャッジ日時 | 2024-10-02 08:27:19 |
合計ジャッジ時間 | 6,949 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 30 ms
10,880 KB |
testcase_01 | AC | 31 ms
10,752 KB |
testcase_02 | AC | 30 ms
10,752 KB |
testcase_03 | WA | - |
testcase_04 | TLE | - |
testcase_05 | -- | - |
testcase_06 | -- | - |
testcase_07 | -- | - |
testcase_08 | -- | - |
testcase_09 | -- | - |
testcase_10 | -- | - |
testcase_11 | -- | - |
ソースコード
import sys sys.setrecursionlimit(10**6) N = int(input()) Total = int(input()) A_list = list(map(int, input().split())) A_list = A_list[::-1] dp_dict = {} def solve(i, j): if (i, j) in dp_dict: return dp_dict[i, j] if i == N-2: if j/A_list[i] == A_list[-1]: return "*" elif j-A_list[i] == A_list[-1]: return "+" else: return None a = solve(i+1, j-A_list[i]) b = None if j % A_list[i] == 0: b = solve(i+1, j/A_list[i]) if a == None and b == None: return None if a == None: dp_dict[(i, j)] = ("*"+b) return "*"+b else: dp_dict[(i, j)] = ("*"+a) return "+"+a print(solve(0, Total))