結果
| 問題 |
No.1630 Sorting Integers (Greater than K)
|
| コンテスト | |
| ユーザー |
carrot46
|
| 提出日時 | 2021-07-30 21:17:27 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 2,793 bytes |
| コンパイル時間 | 2,258 ms |
| コンパイル使用メモリ | 197,128 KB |
| 最終ジャッジ日時 | 2025-01-23 11:02:25 |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 5 |
| other | AC * 21 WA * 1 |
ソースコード
#include <bits/stdc++.h>
#include <atcoder/modint>
using namespace std;
using namespace atcoder;
//#pragma GCC optimize("Ofast")
#define reps(i,s,n) for(int i = s; i < n; i++)
#define rep(i,n) reps(i,0,n)
#define Rreps(i,n,e) for(int i = n - 1; i >= e; --i)
#define Rrep(i,n) Rreps(i,n,0)
#define ALL(a) a.begin(), a.end()
using ll = long long;
using vec = vector<ll>;
using mat = vector<vec>;
ll N,M,H,W,Q,K,A,B;
string S;
using P = pair<ll, ll>;
using tp = tuple<ll, ll, ll>;
const ll INF = (1LL<<60);
template<class T> bool chmin(T &a, const T b){
if(a > b) {a = b; return true;}
else return false;
}
template<class T> bool chmax(T &a, const T b){
if(a < b) {a = b; return true;}
else return false;
}
template<class T> void my_printv(std::vector<T> v,bool endline = true){
if(!v.empty()){
for(std::size_t i{}; i<v.size()-1; ++i) std::cout<<v[i]<<" ";
std::cout<<v.back();
}
if(endline) std::cout<<std::endl;
}
int main() {
cin.tie(nullptr);
ios::sync_with_stdio(false);
cin>>N>>S;
vec c(10, 0);
rep(i, 9) cin>>c[i+1];
if(S.size() > N){
cout<<-1<<endl;
}else if(size(S) < N){
rep(i, 10) rep(j, c[i]) cout<<i;
cout<<endl;
}else{
string res = string(N, '0');
auto res_fill_min = [&](int p){
int pos = -1;
Rrep(i, p) {
++c[res[i]-'0'];
if(i < N - 1 and res[i] < res[i + 1]){
pos = i;
break;
}
}
if(pos == -1){
cout<<-1<<endl;
exit(0);
}else{
reps(i, res[pos] - '0' + 1, 10){
if(c[i]){
--c[i];
res[pos] = '0' + i;
break;
}
}
reps(i, pos + 1, N){
rep(j, 10) {
if(c[j] > 0){
--c[j];
res[i] = '0' + j;
break;
}
}
}
}
};
bool eq = true;
rep(p, N){
char s = S[p];
bool ok = false;
reps(i, eq ? s - '0' : 0, 10) {
if (c[i]) {
--c[i];
ok = true;
if(i != s - '0') eq = false;
res[p] = '0' + i;
break;
}
}
if (!ok) {
res_fill_min(p);
cout<<res<<endl;
return 0;
}
}
if(S == res){
res_fill_min(N);
}
cout<<res<<endl;
}
}
carrot46