結果
| 問題 |
No.1005 BOT対策
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-07-27 10:05:29 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 862 bytes |
| コンパイル時間 | 281 ms |
| コンパイル使用メモリ | 12,800 KB |
| 実行使用メモリ | 10,752 KB |
| 最終ジャッジ日時 | 2024-07-16 17:16:15 |
| 合計ジャッジ時間 | 2,375 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | WA * 3 |
| other | WA * 27 |
ソースコード
S = input()
T = input()
# cnt = S.count(T)
# if len(T) == 1 and cnt == 0:
# print(cnt)
# elif len(T) == 1 and cnt != 0:
# print(-1)
# else:
# print(cnt)
# Z-algorithm
# https://qiita.com/masayoshi361/items/1be110f13412f5431da2
def Z_algo(S):
n = len(S)
LCP = [0]*n
i = 1
j = 0
c = 0 # 最も末尾側までLCPを求めたインデックス
for i in range(1, n):
# i番目からのLCPが以前計算したcからのLCPに含まれている場合
if i+LCP[i-c] < c+LCP[c]:
LCP[i] = LCP[i-c]
else:
j = max(0, c+LCP[c]-i)
while i+j < n and S[j] == S[i+j]:
j += 1
LCP[i] = j
c = i
LCP[0] = n
return LCP
z_results = Z_algo(T+S)
print(z_results)
results = [x for x in z_results[1:] if x >= len(T)]
print(len(results))