結果
問題 |
No.935 う し た ぷ に き あ く ん 笑 ビ - ム
|
ユーザー |
|
提出日時 | 2020-12-26 12:49:36 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 257 ms / 2,000 ms |
コード長 | 706 bytes |
コンパイル時間 | 252 ms |
コンパイル使用メモリ | 82,372 KB |
実行使用メモリ | 75,004 KB |
最終ジャッジ日時 | 2024-09-24 16:02:13 |
合計ジャッジ時間 | 8,949 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 58 |
ソースコード
N = int(input()) S = input().strip() A = list(map(int,input().split())) Q = int(input()) K = list(map(int,input().split())) BS = [0 for _ in range(N+1)] for i in range(1,N+1): if S[i-1]=="E": BS[i] = BS[i-1]+1 else: BS[i] = BS[i-1] BA = [0 for _ in range(N+1)] for i in range(1,N+1): BA[i] = BA[i-1]+A[i-1] for j in range(Q): k = K[j] cmax = 0 for i in range(N): high = N low = i-1 while high-low>1: mid = (high+low)//2 if mid+1<=N and BA[mid+1]-BA[i]>k: high = mid else: low = mid ind = high cnt = BS[high]-BS[i] cmax = max(cmax,cnt) print(cmax)