結果
問題 | No.1996 <>< |
ユーザー |
![]() |
提出日時 | 2022-07-01 23:02:35 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,932 ms / 2,000 ms |
コード長 | 2,243 bytes |
コンパイル時間 | 420 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 128,504 KB |
最終ジャッジ日時 | 2024-11-26 06:49:27 |
合計ジャッジ時間 | 23,742 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 29 |
ソースコード
class SegmrntTree:def __init__(self,arr,func,i_ele):self.i_ele = i_eleself.func = funcarr_len = len(arr)self.tree_len = 2 ** (arr_len-1).bit_length() * 2self.tree = [i_ele] * self.tree_lenfor i in range(arr_len):self.tree[i + self.tree_len // 2] = arr[i]for i in range(self.tree_len // 2 -1,0,-1):self.tree[i] = func(self.tree[i * 2],self.tree[i * 2 + 1])def query_range(self,l,r):res = self.i_elel += self.tree_len // 2 - 1r += self.tree_len // 2while l < r:if l & 1:res = self.func(res,self.tree[l])l += 1if r & 1:res = self.func(res,self.tree[r-1])r -= 1l >>= 1r >>= 1return resdef query(self,l):return self.tree[l + self.tree_len // 2 - 1]def update(self,l,x):l += self.tree_len // 2 - 1self.tree[l] = self.func(x,self.tree[l])def calc(l):if l & 1:l -=1return l >> 1while calc(l):if l & 1:self.tree[calc(l)] = self.func(self.tree[l],self.tree[l-1])else:self.tree[calc(l)] = self.func(self.tree[l],self.tree[l+1])l = calc(l)n,k = map(int,input().split())a = list(map(int,input().split()))s = list(input())from collections import defaultdictd = defaultdict(int)d[0] = 1for i,e in enumerate(sorted(set(a)),start=2):d[e] = id[10**20] = len(d) + 1nn = len(d)dp = []mod = 10 ** 9 + 7def sum_(x,y):return (x + y) % modfor i in range(k+1):dp.append(SegmrntTree([0]*nn,sum_,0))for i in range(1,n+1):idx = d[a[i-1]]dp[0].update(idx,1)for j in range(1,k+1):if s[j-1] == "<":down = dp[j-1].query_range(1,idx-1)dp[j].update(idx,down)else:up = dp[j-1].query_range(idx+1,nn)dp[j].update(idx,up)# for j in range(k+1):# print(dp[j].tree)# print()ans = 0for i in range(1,nn):ans += dp[k].query(i)# print(dp[k].query(i+1))ans %= modprint(ans)