結果
| 問題 | No.1694 ZerOne |
| コンテスト | |
| ユーザー |
eSeF
|
| 提出日時 | 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()
eSeF