转载:https://blog.csdn.net/westbrook1998/article/details/81814305
set 容器模版需要3个泛型参数,如下:
template<class T, class C, class A> class set;
第一个T 是元素类型,必选;
第二个C 指定元素比较方式,缺省为 Less, 即使用 < 符号比较;
第三个A 指定空间分配对象,一般使用默认类型。
因此:
(1) 如果第2个泛型参数你使用默认值的话,你的自定义元素类型需要重载 < 运算操作;
(2)如果你第2个泛型参数不使用默认值的话,则比较对象必须具有 () 操作,即:
bool operator()(const T &a, const T &b)
例子:
#include <cstdio> #include <algorithm> #include <set> using namespace std; int m,k; struct cmp{ bool operator() (int a,int b){ if(abs(a-b)<=k){ return false; } else{ return a<b; } } }; set<int,cmp> s; char op[10]; int x; int main(void){ scanf("%d%d",&m,&k); while(m--){ scanf("%s%d",op,&x); if(op[0]=='a'){ if(s.find(x)==s.end()){ s.insert(x); } } else if(op[0]=='d'){ s.erase(x); } else{ if(s.find(x)!=s.end()){ puts("Yes"); } else{ puts("No"); } } } return 0; }
原文链接: https://www.cnblogs.com/zhihaospace/p/12843802.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;
也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/346898
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!