如何优雅地实现判断一个值是否在一个集合中?
生活随笔
收集整理的這篇文章主要介紹了
如何优雅地实现判断一个值是否在一个集合中?
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
如何判斷某變量是否在某個集合中?注意,這里的集合可能并不是指確定的常量,也可能是變量。
版本0
#include? 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? #include? 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? //?單參 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;elsereturn?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,可參考:
#include? 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; }總結
我反正是學廢了。你還有什么好的方法?
聲明:
本文于網絡整理,版權歸原作者所有,如來源信息有誤或侵犯權益,請聯系我們刪除或授權事宜。
總結
以上是生活随笔為你收集整理的如何优雅地实现判断一个值是否在一个集合中?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 苹果iPhone天气应用多次“崩溃”怎么
- 下一篇: 骚操作:利用强弱符号制作插件库