結果
問題 |
No.1694 ZerOne
|
ユーザー |
![]() |
提出日時 | 2020-10-10 00:28:43 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 471 ms / 2,000 ms |
コード長 | 806 bytes |
コンパイル時間 | 91 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 12,416 KB |
最終ジャッジ日時 | 2024-07-19 09:37:18 |
合計ジャッジ時間 | 4,840 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 31 |
ソースコード
def main(): S=input() N=len(S) Zero=S.count('0') One=N-Zero cnt=[0]*4 for i in range(N): if S[i]=='0': cnt[0]+=(i+1) cnt[1]+=N-i else: cnt[2]+=(i+1) cnt[3]+=N-i L=0 Z=0 if Zero<=One: Z=Zero L=min(cnt[0],cnt[1]) else: Z=One L=min(cnt[2],cnt[3]) dp=[[0 for i in range(L+1)] for j in range(Z+1)] dp[0][0]=1 for i in range(1,N+1): ndp=[[0 for i in range(L+1)] for j in range(Z+1)] for j in range(Z+1): for k in range(L+1): ndp[j][k]+=dp[j][k] if j>0 and k-i>=0: ndp[j][k]+=dp[j-1][k-i] ndp[j][k] dp=ndp print(dp[Z][L]) if __name__=='__main__': main()