結果
| 問題 | No.318 学学学学学 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2016-10-20 10:38:30 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0 + boost 1.89.0) |
| 結果 |
MLE
|
| 実行時間 | - |
| コード長 | 1,361 bytes |
| 記録 | |
| コンパイル時間 | 777 ms |
| コンパイル使用メモリ | 80,556 KB |
| 実行使用メモリ | 1,436,416 KB |
| 最終ジャッジ日時 | 2024-11-23 14:38:12 |
| 合計ジャッジ時間 | 91,466 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | MLE * 3 |
| other | WA * 1 TLE * 2 MLE * 23 |
ソースコード
#include <iostream>
#include <vector>
#include <map>
using namespace std;
int main(){
int n=0;cin>>n;
vector<int> va(n);
map<int,string> m;
for(int i=0;i<n;++i){
cin>>va[i];
map<int,string>::iterator it=m.find(va[i]);
if(it!=m.end()){
string s=m[va[i]];
int f=0;
int pos=0;
int ss=s.size();
for(int j=0;j<ss;++j){
if(f==1){
s.erase(s.begin()+pos);
}
if(s[j]==','){
f=1;
pos=j+1;
}
}
s+=to_string(i);
m[va[i]]=s;
} else {
string s=to_string(i);
s+=",";
s+=to_string(i);
m.insert(make_pair(va[i],s));
}
}
vector<int> vb(n);
int sum=0;
for(auto i=m.size()-1;i>=0;--i){
if(sum==n) break;
string s=m[i];
int l=0,r=0;
string t;
int f=0;
for(int j=0;j<s.size();++j){
if(s[j]==','){
f=1;
if(t.size()>1){
l=stoi(t);
} else {
l=t[0];
l-=48;
}
t.clear();
}
if(f==0){
t+=s[j];
} else if(s[j]!=','){
t+=s[j];
}
}
if(t.size()>1){
r=stoi(t);
} else {
r=t[0];
r-=48;
}
for(int j=l;j<=r;++j){
if(vb[j]==0){
vb[j]=i;
sum+=1;
}
}
}
for(int i=0;i<n;++i){
cout<<vb[i]<<" ";
}
cout<<endl;
}