結果
問題 | No.603 hel__world (2) |
ユーザー | chocorusk |
提出日時 | 2020-02-23 17:43:20 |
言語 | Python3 (3.12.2 + numpy 1.26.4 + scipy 1.12.0) |
結果 |
AC
|
実行時間 | 1,345 ms / 3,000 ms |
コード長 | 1,509 bytes |
コンパイル時間 | 87 ms |
コンパイル使用メモリ | 12,928 KB |
実行使用メモリ | 62,700 KB |
最終ジャッジ日時 | 2024-10-10 05:22:00 |
合計ジャッジ時間 | 26,671 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 479 ms
50,716 KB |
testcase_01 | AC | 503 ms
50,764 KB |
testcase_02 | AC | 478 ms
50,936 KB |
testcase_03 | AC | 481 ms
50,764 KB |
testcase_04 | AC | 504 ms
50,780 KB |
testcase_05 | AC | 510 ms
50,760 KB |
testcase_06 | AC | 511 ms
50,592 KB |
testcase_07 | AC | 482 ms
50,824 KB |
testcase_08 | AC | 491 ms
50,868 KB |
testcase_09 | AC | 481 ms
50,712 KB |
testcase_10 | AC | 487 ms
50,764 KB |
testcase_11 | AC | 1,192 ms
62,312 KB |
testcase_12 | AC | 1,169 ms
62,188 KB |
testcase_13 | AC | 1,188 ms
62,252 KB |
testcase_14 | AC | 489 ms
50,920 KB |
testcase_15 | AC | 503 ms
50,724 KB |
testcase_16 | AC | 493 ms
50,752 KB |
testcase_17 | AC | 480 ms
50,720 KB |
testcase_18 | AC | 491 ms
50,760 KB |
testcase_19 | AC | 486 ms
50,856 KB |
testcase_20 | AC | 1,104 ms
52,692 KB |
testcase_21 | AC | 1,051 ms
52,864 KB |
testcase_22 | AC | 494 ms
50,780 KB |
testcase_23 | AC | 505 ms
50,720 KB |
testcase_24 | AC | 496 ms
50,764 KB |
testcase_25 | AC | 1,345 ms
62,056 KB |
testcase_26 | AC | 1,325 ms
62,700 KB |
testcase_27 | AC | 1,310 ms
62,316 KB |
testcase_28 | AC | 1,300 ms
60,648 KB |
testcase_29 | AC | 1,082 ms
52,676 KB |
testcase_30 | AC | 886 ms
51,788 KB |
testcase_31 | AC | 501 ms
50,780 KB |
testcase_32 | AC | 1,140 ms
52,756 KB |
ソースコード
from decimal import * from fractions import Fraction getcontext().prec=55 mod=10**6+3 invs=[0]*mod invs[1]=1 for i in range(2, mod): invs[i]=mod-invs[mod%i]*(mod//i)%mod def solve(x, v): m=len(v) if m==0: return 1 s=sum(v) if x<s: return 0 elif x==s: return 1 v.sort() vs=[] cnt2=1 for i in range(1, m): if v[i]!=v[i-1]: vs.append((v[i-1], cnt2)) cnt2=0 cnt2+=1 vs.append((v[m-1], cnt2)) l=Decimal(1) r=Decimal(max(v)+2) for _ in range(120): mid=(l+r)/Decimal(2) cnt=0 for p in vs: cnt+=p[1]*int(Decimal(p[0])/(mid-Decimal(1))) if cnt<x-s: r=mid else: l=mid ret=1 cnt=0 f=Fraction(10**19, 1) for p in vs: k=int(Decimal(p[0])/(l-Decimal(1))) if k==0: continue f=min(f, Fraction(p[0]+k, k)) cnt+=k*p[1] for i in range(p[0]): ret=ret*pow((k+i+1)*invs[i+1]%mod, p[1], mod)%mod p=f.numerator q=f.denominator ret*=pow(q, cnt-(x-s), mod)*pow(p, mod-1-(cnt-(x-s))%(mod-1), mod) ret%=mod return ret v=[[] for i in range(26)] x=list(map(int, input().split())) t=input() n=len(t) cnt=1 for i in range(1, n): if t[i]!=t[i-1]: v[ord(t[i-1])-ord('a')].append(cnt) cnt=0 cnt+=1 v[ord(t[n-1])-ord('a')].append(cnt) ans=1 for i in range(26): a=solve(x[i], v[i]) #print(a) ans=ans*a%mod print(ans)