Pagini recente » Cod sursa (job #1294136) | Cod sursa (job #867060) | Cod sursa (job #106571) | Profil IuliaCristianaM | Cod sursa (job #1685629)
#include<fstream>
#include<set>
#include<cstring>
using namespace std;
ifstream fin("zeap.in");
ofstream fout("zeap.out");
set<int> v;
multiset<int> dif;
set<int>::iterator it, it1;
multiset<int>::iterator IT;
int n, k;
char s[50], c[5];
int main(){
n = 0;
while( fin.get(s,45) ){
n = strlen( s );
k = -1;
int i = 0;
for( i = 0; i < n; i++){
if( s[i] != ' ' ){
c[++k] = s[i];
}else{
break;
}
}
i++;
int number = 0;
for( ; i < n; i++ ){
number = number * 10 + ( s[i] - '0' );
}
if( c[0] == 'I' ){
v.insert( number );
if( v.size() > 1 ){
it1 = v.end();
it1--;
it = it1;
it1--;
dif.insert( (*it) - (*it1) );
}
}
if( c[0] == 'S' ){
it = v.find( number );
if( it != v.end() ){
it1 = it;
if( v.begin() != it ){
it--;
IT = dif.find( (*it1) - (*it) );
dif.erase( IT );
}
it = it1;
it1++;
IT = dif.find( (*it1) - (*it) );
dif.erase( IT );
it--;
dif.insert( (*it1) - (*it) );
it++;
v.erase( it );
}else{
fout << "-1\n";
}
}
if( c[0] == 'C' ){
it = v.find( number );
if( it != v.end() ){
fout << "1\n";
}else{
fout << "0\n";
}
}
if( c[0] == 'M' && c[1] == 'A' ){
if( v.size() > 1 ){
it = v.end();
it--;
it1 = v.begin();
fout << ( (*it) - (*it1) ) << "\n";
}else{
fout << "-1\n";
}
}
if( c[0] == 'M' && c[1] == 'I' ){
IT = dif.begin();
fout << (*IT) << "\n";
}
fin.get();
}
return 0;
}