set的头文件为< set >,提供了如下操作:
(1)s.begin() 返回指向第一个元素的迭代器。
(2)s.clear() 清除所有元素。
(3)s.count() 返回某个值元素的个数。
(4)s.empty() 如果集合为空,返回true(真)。
(5)s.end() 返回指向最后一个元素之后的迭代器,不是最后一个元素。
(6)s.erase() 删除集合中的元素。
(7)s.find() 返回一个指向被查找到元素的迭代器。
(8)s.insert() 在集合中插入元素。
(9)s.max_size() 返回集合能容纳的元素的最大限值。
(10)s.size() 集合中元素的数目。
(11)s.swap() 交换两个集合变量。
set放入一个元素就会调整这个元素的位置,把它放到合适的位置,所以set中只有一个insert插入操作,而且set不能保存相同的元素。
例一:日期问题
set 迭代器 iterator:按从小到大读取set中元素。
#include<set>
#include<iostream>
using namespace std;
set<int> s;
int main(){
set< int >::iterator iter;
s.insert(50);
s.insert(100);
for(iter = s.begin(); iter != s.end(); iter++)
{
cout<<*iter<<" ";
}
}
小明正在整理一批历史文献。这些历史文献中出现了很多日期。小明知道这些日期都在1960年1月1日至2059年12月31日。令小明头疼的是,这些日期采用的格式非常不统一,有采用年/月/日的,有采用月/日/年的,还有采用日/月/年的。更加麻烦的是,年份也都省略了前两位,使得文献上的一个日期,存在很多可能的日期与其对应。
比如02/03/04,可能是2002年03月04日、2004年02月03日或2004年03月02日。
给出一个文献上的日期,你能帮助小明判断有哪些可能的日期对其对应吗?
输入
一个日期,格式是"AA/BB/CC"。 (0 <= A, B, C <= 9)
输出
输出若干个不相同的日期,每个日期一行,格式是"yyyy-MM-dd"。多个日期按从早到晚排列。
样例输入
02/03/04
样例输出
2002-03-04
2004-02-03
2004-03-02
题意:在给定的文献日期上,判断有哪些可能的日期对其对应。
这道题主要考查细节
①、考虑年份是否为闰年
②、不同月份的长度
③、若有多个可能日期,则按从早到晚排列
set 迭代器 iterator:排序、去重
#include<bits/stdc++.h>
using namespace std;
char s[10];
int run[15]={
0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
int fr[