Alice là một kĩ sư đang làm việc trên một loại vi xử lí mới. Bộ vi xử lí làm việc trên tập số nguyên không âm (các số có thể được xuất hiện nhiều lần) để mô phỏng sự sống trong Matrix. Ban đầu tập là rỗng, bộ vi xử lí có các loại truy vấn sau:
Truy vấn dạng: , truy vấn này thêm một số nguyên vào . Nếu giá trị đã có trong thì truy vấn này vẫn được thực hiện;
Truy vấn dạng: , truy vấn này xóa một số khỏi . Nếu giá trị không thuộc thì truy vấn này không cần làm gì. Nếu giá trị xuất hiện nhiều lần trong thì truy vấn này chỉ xóa đi một lần;
Truy vấn dạng: , truy vấn này thay đổi cả phần tử của với sự ảnh hưởng của . Cụ thể, với thuộc được thay bằng . Phép toán XOR (trong các ngôn ngữ lập trình thường được kí hiệu là ^) được định nghĩa như sau: Kết quả của phép toán XOR giữa hai số nguyên không âm và là một số nguyên không âm trong đó bit thứ trong biểu diễn nhị phân của sẽ là khi bit thứ trong biểu diễn nhị phân của và bằng nhau (đồng thời bằng hoặc ), ngược lại bit thứ trong biểu diễn nhị phân của sẽ là ;
Truy vấn dạng: , truy vấn này tính tổng phần tử nhỏ nhất trong .
Để kiểm tra trước khi đưa vào sử dụng, Alice muốn bạn lập trình xử lí các kiểm tra lại các truy vấn.
Dữ liệu vào:
Dòng thứ nhất chứa số nguyên dương ;
Dòng thứ trong dòng tiếp theo chứa hai số nguyên mô tả loại truy vấn.
Các số trên cùng một dòng cách nhau bởi dấu cách.
Dữ liệu ra:
Với mỗi truy vấn loại , hãy in ra tổng của phần tử nhỏ nhất trong trên một dòng.
Ví dụ:
Dữ liệu vào:
6
0 1
2 2
0 3
3 2
2 2
3 1
Dữ liệu ra:
6
1
Giới hạn:
Có số điểm của bài thỏa mãn: ;
số điểm khác của bài thỏa mãn: và không có truy vấn loại ;