https://codeforces.com/problemset/problem/1413/D
思路:
以前写过一遍了。
每次支出的都是当前残留的+号中费用最小的。前往后不好确定,但是后往前的话可以发现栈中top()<新进来的数的话一定是不成立的。因为按照顺序是先拿最小的。
#include<iostream>
#include<vector>
#include<queue>
#include<cstring>
#include<cmath>
#include<stack>
#include<map>
#include<set>
#include<cstdio>
#include<algorithm>
#define debug(a) cout<<#a<<"="<<a<<endl;
using namespace std;
const int maxn=1e5*2+1000;
typedef long long LL;
inline LL read(){LL x=0,f=1;char ch=getchar(); while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}while (isdigit(ch)){x=x*10+ch-48;ch=getchar();}
return x*f;}
struct P{
char op;LL num;
}a[maxn];
stack<LL>s;
vector<LL>v;
int main(void)
{
cin.tie(0);std::ios::sync_with_stdio(false);
LL n;cin>>n;
for(LL i=1;i<=2*n;i++){
cin>>a[i].op;
if(a[i].op=='+') a[i].num=-1;
else if(a[i].op=='-') cin>>a[i].num;
}
for(LL i=2*n;i>=1;i--){
if(a[i].op=='-'){
if(s.empty()||s.top()>a[i].num) s.push(a[i].num);
else if(!s.empty()&&s.top()<a[i].num){
cout<<"NO"<<"\n";
return 0;
}
}
else if(a[i].op=='+'){
if(s.empty()){
cout<<"NO"<<"\n";
return 0;
}
else{
v.push_back(s.top());
s.pop();
}
}
}
cout<<"YES"<<"\n";
reverse(v.begin(),v.end());
for(auto i:v){
cout<<i<<" ";
}
cout<<"\n";
return 0;
}