結果
問題 | No.2454 Former < Latter |
ユーザー | sotanishy |
提出日時 | 2023-09-01 21:53:32 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 167 ms / 2,000 ms |
コード長 | 756 bytes |
コンパイル時間 | 390 ms |
コンパイル使用メモリ | 82,708 KB |
実行使用メモリ | 78,756 KB |
最終ジャッジ日時 | 2025-01-03 08:20:50 |
合計ジャッジ時間 | 3,168 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 23 |
ソースコード
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: cnt += 1 elif z[i] == i and i+z[i] < N: cnt += 1 elif i+z[i] < N and S[z[i]] < S[i+z[i]]: cnt += 1 print(cnt)