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

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

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

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

[[373401]]

版本0

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

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

版本1

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

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

  1. std::set<decltype(a)> con_set = {1, 2, 3, 4, 5}; 

版本2

  1. #include <iostream> 
  2. // 单参 
  3. template <typename T> 
  4. inline bool IsContains(const T& target) { 
  5.   return false; 
  6.  
  7. template <typename T, typename... Args> 
  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"<<std::endl
  17.     } 
  18.     return 0; 

模板,通用做法。

版本3

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

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

  1. #include <iostream> 
  2. template <typename T, typename... Args> 
  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"<<std::endl
  9.     } 
  10.     return 0; 

 

责任编辑:赵宁宁 来源: 编程珠玑
相关推荐

2020-02-05 14:05:21

Java技术数组

2018-12-14 09:32:06

亿级数据存在

2018-12-14 09:16:31

装载数据数组

2020-10-14 06:18:20

Golang字符串数组

2020-12-11 11:19:54

区块链资金投资

2020-08-24 08:07:32

Node.js文件函数

2022-06-21 14:44:38

接口数据脱敏

2024-11-07 10:55:26

2024-11-08 15:56:36

2017-12-12 15:24:32

Web Server单线程实现

2023-08-01 08:54:02

接口幂等网络

2017-10-10 14:41:38

Linux

2018-12-29 08:15:28

Tomcat应用部署

2023-03-01 09:39:40

调度系统

2023-02-26 01:37:57

goORM代码

2020-09-29 07:24:14

Python字典数据

2023-09-19 23:21:48

Python列表

2024-01-26 12:35:25

JavaScript项目软件包

2020-08-17 08:20:16

iOSAOP框架

2022-05-16 08:17:36

装饰器模式
点赞
收藏

51CTO技术栈公众号