結果
問題 |
No.2454 Former < Latter
|
ユーザー |
![]() |
提出日時 | 2023-09-01 21:49:55 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 666 bytes |
コンパイル時間 | 363 ms |
コンパイル使用メモリ | 82,560 KB |
実行使用メモリ | 78,976 KB |
最終ジャッジ日時 | 2025-01-03 08:13:27 |
合計ジャッジ時間 | 3,700 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 15 WA * 8 |
ソースコード
import sys input = sys.stdin.readline def z_array(s): n = len(s) z = [0] * n z[0] = n l = r = 0 for i in range(1, n): k = i - l if i <= r and z[k] < r - i + 1: z[i] = z[k] else: l = i if i > r: r = i while r < n and s[r - l] == s[r]: r += 1 r -= 1 z[i] = r - l + 1 return z T = int(input()) for _ in range(T): N = int(input()) S = input().rstrip() z = z_array(S) cnt = 0 for i in range(1, N): if z[i] > i or (i+z[i] < N and S[z[i]] < S[i+z[i]]): cnt += 1 print(cnt)