結果
問題 |
No.1630 Sorting Integers (Greater than K)
|
ユーザー |
![]() |
提出日時 | 2021-07-30 21:54:46 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 966 bytes |
コンパイル時間 | 457 ms |
コンパイル使用メモリ | 82,048 KB |
実行使用メモリ | 104,100 KB |
最終ジャッジ日時 | 2024-09-16 00:00:03 |
合計ジャッジ時間 | 4,146 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 5 |
other | AC * 21 WA * 1 |
ソースコード
N,K=input().split() N=int(N) if len(K)>N: print(-1) exit() K=''.join(['0'*(N-len(K)),K]) X=[int(K[i]) for i in range(N)] X[-1]+=1 for i in range(N-1,-1,-1): if X[i]==10: X[i]=0 if i==0: print(-1) exit() X[i-1]+=1 C=[0]+list(map(int,input().split())) ANS=[0]*N for i in range(N): if C[X[i]]==0: for j in range(X[i]+1,10): if C[j]: ANS[i]=j C[j]-=1 i+=1 for k in range(10): for l in range(C[k]): ANS[i]=k i+=1 print(*ANS,sep='') exit() i-=1 while 1: if i==-1: print(-1) exit() C[ANS[i]]+=1 ANS[i]=0 for j in range(X[i]+1,10): if C[j]: ANS[i]=j C[j]-=1 i+=1 for k in range(10): for l in range(C[k]): ANS[i]=k i+=1 print(*ANS,sep='') exit() i-=1 else: ANS[i]=X[i] C[X[i]]-=1