import java.util.*;
public class Main {
private static TreeMap<Integer,Integer> hashMap=new TreeMap<>();
private static int total=0;//注意必须用,用来计算数量,如果自己调用方法计算,则会超时
public static void insertValue(int x) {
// TODO: 实现插入逻辑
if(hashMap.containsKey(x)){
hashMap.put(x,hashMap.get(x)+1);
total++;
}else{
hashMap.put(x,1);
total++;
}
}
public static void eraseValue(int x) {
// TODO: 实现删除逻辑
if(hashMap.containsKey(x)){
if(hashMap.get(x)>1){
hashMap.put(x,hashMap.get(x)-1);
total--;
}else{
hashMap.remove(x);
total--;
}
}
}
public static int xCount(int x) {
// TODO: 求x在集合中的个数
return hashMap.getOrDefault(x,0);
}
public static int sizeOfSet() {
// TODO: 返回集合大小
return total;
}
public static int getPre(int x) {
// TODO: 实现找前驱
Integer result=hashMap.lowerKey(x);
return result==null?-1:result;
}
public static int getBack(int x) {
// TODO: 实现找后继
Integer result=hashMap.higherKey(x);
return result==null?-1:result;
}
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int q = scanner.nextInt();
while (q-- > 0) {
int op = scanner.nextInt();
switch (op) {
case 1:
insertValue(scanner.nextInt());
break;
case 2:
eraseValue(scanner.nextInt());
break;
case 3:
System.out.println(xCount(scanner.nextInt()));
break;
case 4:
System.out.println(sizeOfSet());
break;
case 5:
System.out.println(getPre(scanner.nextInt()));
break;
case 6:
System.out.println(getBack(scanner.nextInt()));
break;
}
}
scanner.close();
}
}