如何优雅地实现判断一个值是否在一个集合中?

本文转载自公众号“编程珠玑”(ID:shouwangxiansheng)。

如何判断某变量是否在某个集合中?注意,这里的集合可能并不是指确定的常量,也可能是变量。

版本0

 
 
 
  1. #include  
  2. int main(){ 
  3.     int a = 5; 
  4.     if(a == 1 || a == 2 || a == 3 || a == 4 || a == 5){ 
  5.         std::cout<<"find it"<
  6.     } 
  7.     return 0; 

常规做法,小集合的时候比较方便,观感不佳。

版本1

 
 
 
  1. #include  
  2. #include  
  3. int main(){ 
  4.     int a = 5; 
  5.     std::set con_set = {1, 2, 3, 4, 5};  
  6.     if(con_set.find(a) != con_set.end()){ 
  7.         std::cout<<"find it"<
  8.     } 
  9.     return 0; 

不够通用;不是常数的情况下,还要临时创建set,性能不够,性价比不高。当然通用一点你还可以这样写:

 
 
 
  1. std::set con_set = {1, 2, 3, 4, 5}; 

版本2

 
 
 
  1. #include  
  2. // 单参 
  3. template  
  4. inline bool IsContains(const T& target) { 
  5.   return false; 
  6.  
  7. template  
  8. inline bool IsContains(const T& target, const T& cmp_target, const Args&... args) { 
  9.   if (target == cmp_target) 
  10.     return true; 
  11.   else 
  12.     return IsContains(target, args...); 
  13. int main(){ 
  14.     int a = 6; 
  15.     if(IsContains(a,1,2,3,4,5)){ 
  16.         std::cout<<"find it"<
  17.     } 
  18.     return 0; 

模板,通用做法。

版本3

需要C++17支持:,涉及的特性叫做fold expression,可参考:

https://en.cppreference.com/w/cpp/language/fold

 
 
 
  1. #include  
  2. template  
  3. inline bool IsContains(const T& target, const Args&... args) { 
  4.     return (... || (target == args)); 
  5. int main(){ 
  6.     int a = 5; 
  7.     if(IsContains(a,1,2,3,4,5)){ 
  8.         std::cout<<"find it"<
  9.     } 
  10.     return 0; 

当前标题:如何优雅地实现判断一个值是否在一个集合中?
网页链接:http://www.csdahua.cn/qtweb/news23/370673.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网