您现在的位置是:首页 > Javascript
当前栏目
如何优雅地实现判断一个值是否在一个集合中?
2023-03-14 09:36:26 时间
本文转载自公众号“编程珠玑”(ID:shouwangxiansheng)。
如何判断某变量是否在某个集合中?注意,这里的集合可能并不是指确定的常量,也可能是变量。
版本0
- #include <iostream>
- int main(){
- int a = 5;
- if(a == 1 || a == 2 || a == 3 || a == 4 || a == 5){
- std::cout<<"find it"<<std::endl;
- }
- return 0;
- }
常规做法,小集合的时候比较方便,观感不佳。
版本1
- #include <iostream>
- #include <set>
- int main(){
- int a = 5;
- std::set<int> con_set = {1, 2, 3, 4, 5};
- if(con_set.find(a) != con_set.end()){
- std::cout<<"find it"<<std::endl;
- }
- return 0;
- }
不够通用;不是常数的情况下,还要临时创建set,性能不够,性价比不高。当然通用一点你还可以这样写:
- std::set<decltype(a)> con_set = {1, 2, 3, 4, 5};
版本2
- #include <iostream>
- // 单参
- template <typename T>
- inline bool IsContains(const T& target) {
- return false;
- }
- template <typename T, typename... Args>
- inline bool IsContains(const T& target, const T& cmp_target, const Args&... args) {
- if (target == cmp_target)
- return true;
- else
- return IsContains(target, args...);
- }
- int main(){
- int a = 6;
- if(IsContains(a,1,2,3,4,5)){
- std::cout<<"find it"<<std::endl;
- }
- return 0;
- }
模板,通用做法。
版本3
需要C++17支持:,涉及的特性叫做fold expression,可参考:
https://en.cppreference.com/w/cpp/language/fold
- #include <iostream>
- template <typename T, typename... Args>
- inline bool IsContains(const T& target, const Args&... args) {
- return (... || (target == args));
- }
- int main(){
- int a = 5;
- if(IsContains(a,1,2,3,4,5)){
- std::cout<<"find it"<<std::endl;
- }
- return 0;
- }
相关文章
- Windows11这鸡肋功能太烦人?教你关闭系统小组件
- Windows 11小组件:你需要知道的一切
- HarmonyOS ArkUI之自定义组件侧滑菜单(JS)
- HarmonyOS自定义组件之分页功能组件封装实例
- 微软:2022年将重点解决Windows性能低下的问题
- HarmonyOS ArkUI之仿微信朋友圈图片预览
- Django3 使用 WebSocket 实现 WebShell
- 分库分表实战之订单业务完整梳理
- 太上老君的炼丹炉之分布式 Quorum NWR
- JeecgBoot的前端Form升级为FormModel用法
- 前端进阶:原生JavaScript实现具有进度监听的文件上传预览组件
- 如何编写神奇的「插件机制」,优化基于 Antd Table 封装表格的混乱代码
- Java8新特性系列-默认方法和静态方法
- Web开发应了解的5种设计模式
- 死磕JS:Reflect.ownKeys() 和 Object.keys() 怎么选?
- 看完这篇,再也不会害怕别人问我什么是原型了
- 为何每次用完 ThreadLocal 都要调用 remove()
- 软件工程必看——10条你最容易忽视的经典法则
- 浅析Dotnet的垃圾回收
- 前端基础知识整理汇总(下)