sdut 2159:Ivan comes again!(第一届山东省省赛原题,STL之set使用)
Ivan comes again!
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目描述
This is the enhanced version of Problem H.
There is a large matrix whose row and column are less than or equal to 1000000000. And there are three operations for the matrix:
1)add: Mark an element in the matrix. The element wasn’t marked before it is marked.
2)remove: Delete an element’s mark. The element was marked before the element’s mark is deleted.
3)find: Show an element’s row and column, and return a marked element’s row and column, where the marked element’s row and column are larger than the showed element’s row and column respectively. If there are multiple solutions, return the element whose row is the smallest; and if there are still multiple solutions, return the element whose column is the smallest. If there is no solution, return -1.
Of course, Saya comes to you for help again.
输入
The first line of input in each test case contains one integer N (0<N≤200000), which represents the number of operations.
Each of the next N lines containing an operation, as described above.
The last case is followed by a line containing one zero.
输出
示例输入
4
add 2 3
find 1 2
remove 2 3
find 1 2 0
示例输出
Case 1:
2 3
-1
提示
来源
【set使用心得】
begin() 返回指向第一个元素的迭代器
ps:迭代器可以理解为“指针”,使用的使用和指针一样使用。
例如:
set <int> s; //定义一个集合set
set <int>::iterator it; //定义一个set<int>的迭代器
it = s.begin();
cout<<*it<<endl; //输出迭代器指向的元素的值
或者:
set <pair<int,int>> s;
set <pair<int,int>>::iterator it; //定义一个迭代器
it = s.begin();
cout<<it->first<<' '<<it->second<<endl; //输出迭代器指向的元素的值
clear() 清除所有元素
count() 返回某个值元素的个数
empty() 如果集合为空,返回true(真)
end() 返回指向最后一个元素之后的迭代器,不是最后一个元素
equal_range() 返回集合中与给定值相等的上下限的两个迭代器
ps:某个值的[val)区间的两个值。>=val的第一个值作为下限,>val的第一个值作为上限
erase() 删除集合中的元素
ps:删除值为val的元素直接用s.erase(val);或者可以删除迭代器指向那个元素
find() 返回一个指向被查找到元素的迭代器
ps:注意返回的是一个迭代器
get_allocator() 返回集合的分配器
insert() 在集合中插入元素
ps:要插入某个元素,直接s.insert(val);即可
lower_bound() 返回指向大于(或等于)某值的第一个元素的迭代器
ps:返回>=val的第一个元素的迭代器
key_comp() 返回一个用于元素间值比较的函数
max_size() 返回集合能容纳的元素的最大限值
rbegin() 返回指向集合中最后一个元素的反向迭代器
rend() 返回指向集合中第一个元素的反向迭代器
size() 集合中元素的数目
swap() 交换两个集合变量
upper_bound() 返回大于某个值元素的迭代器
ps:返回>val的第一个元素的迭代器
value_comp() 返回一个用于比较元素间的值的函数
这道题拿来熟悉STL很不错。
#include <iostream>
#include <stdio.h>
#include <set>
#include <utility>
using namespace std;
int main()
{
int cnt,n;
for(cnt=;cin>>n;cnt++){
if(n==) break;
getchar();
int i;
char str[];
int a,b;
set < pair<int,int> > s;
set < pair<int,int> >::iterator it; //定义迭代器
cout<<"Case "<<cnt<<':'<<endl;
for(i=;i<=n;i++){
cin>>str>>a>>b;
switch(str[]){
case 'a':
s.insert(make_pair(a,b)); //像集合s中插入pair(a,b)
break;
case 'r':
s.erase(make_pair(a,b)); //将集合s中值为pair(a,b)的元素删掉
break;
case 'f':
it = s.upper_bound(make_pair(a,b)); //返回集合中大于pair(a,b)的第一个元素
for(;it!=s.end();it++) //找到第一个比pair(a,b)大的元素
if(it->first > a && it->second > b)
break;
if(it==s.end())
cout<<-<<endl;
else
cout<<it->first<<' '<<it->second<<endl;
break;
default:break;
}
}
cout<<endl;
}
return ;
}
Freecode : www.cnblogs.com/yym2013
sdut 2159:Ivan comes again!(第一届山东省省赛原题,STL之set使用)的更多相关文章
- sdut 2158:Hello World!(第一届山东省省赛原题,水题,穷举)
Hello World! Time Limit: 1000MS Memory limit: 65536K 题目描述 We know that Ivan gives Saya three problem ...
- sdut 2152:Balloons(第一届山东省省赛原题,DFS搜索)
Balloons Time Limit: 1000MS Memory limit: 65536K 题目描述 Both Saya and Kudo like balloons. One day, the ...
- sdut 2153:Clockwise(第一届山东省省赛原题,计算几何+DP)
Clockwise Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 Saya have a long necklace with ...
- sdut 2154:Shopping(第一届山东省省赛原题,水题)
Shopping Time Limit: 1000MS Memory limit: 65536K 题目描述 Saya and Kudo go shopping together.You can ass ...
- sdut 2165:Crack Mathmen(第二届山东省省赛原题,数论)
Crack Mathmen Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 Since mathmen take securit ...
- sdut 2162:The Android University ACM Team Selection Contest(第二届山东省省赛原题,模拟题)
The Android University ACM Team Selection Contest Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里 ...
- sdut 2163:Identifiers(第二届山东省省赛原题,水题)
Identifiers Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 Identifier is an important c ...
- sdut 2603:Rescue The Princess(第四届山东省省赛原题,计算几何,向量旋转 + 向量交点)
Rescue The Princess Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 Several days ago, a b ...
- sdut 2416:Fruit Ninja II(第三届山东省省赛原题,数学题)
Fruit Ninja II Time Limit: 5000MS Memory limit: 65536K 题目描述 Have you ever played a popular game name ...
随机推荐
- MySQL中group_concat函数
本文通过实例介绍了MySQL中的group_concat函数的使用方法,比如select group_concat(name) .MySQL中group_concat函数完整的语法如下:group_c ...
- 【linux】查看内存和CPU使用情况
1.内存命令:free 解释:以上数据单位KB. 所以,上面的mem物理内存共1G 下面是对这些数值的解释: total:总计物理内存的大小. used:已使用多大. free:可用有多少. Shar ...
- MySQL比较两个表不同的数据
在本教程中,您将学习如何比较两个表以找到不匹配的记录. 在数据迁移中,我们经常需要比较两个表,以便在一个表中标识另一个表中没有相应记录的记录. 例如,我们有一个新的数据库,其架构与旧数据库不同.我们的 ...
- 后台管理-基于 Bootstrap 开发的网站后台管理面板
Bootstrap 开发框架真的很强大,今天推荐几个非常不错的基于 Bootstrap 开发的网站后台管理面板,全部都是响应式布局,细节做得都很不错.可以搜索keenthemes. Metronic ...
- C# “预先生成事件命令行”和“后期生成事件命令行”
概述 Visual studio 项目允许在项目属性生成事件一栏中指定预先生成和后期生成事件来实现项目生成与部署的自动化. 实例1: 我自己写了一个调试工具,该工具处于一边开发一边使用过程中.实际工作 ...
- python 火车票爬取代码
1.根据搜索词下载百度图片: # -*- coding: utf-8 -*- """根据搜索词下载百度图片""" import re imp ...
- jdbc链接基础
1 jdbc 链接两种方式,通过jdbc链接mysql数据库,url:jdbc:mysql://ip:端口[/database name] 通过什么驱动器,链接什么数据库,数据库的ip,连接端口,可以 ...
- AngularJS 中 Provider 的用法及区别
在一个分层良好的 Angular 应用中,Controller 这一层应该很薄.也就是说,应用里大部分的业务逻辑和持久化数据都应该放在 Service 里. 为此,理解 AngularJS 中的几个 ...
- Atitit.软件仪表盘(2)--vm子系统--资源占用监测
Atitit.软件仪表盘(2)--vm子系统--资源占用监测 1. Jvisualvm.exe 2. jprofile 3. Heap //permgen monitor 作者::老哇的爪子At ...
- IOS 获取设备屏幕的尺寸
// 不包含状态栏 CGRect rect1 = [UIScreen mainScreen].applicationFrame; // 包含状态栏(整个屏幕) CGRect rect2 = [[UIS ...