加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

检查动态分配的数组C中是否存在元素

发布时间:2020-12-16 10:34:18 所属栏目:百科 来源:网络整理
导读:例如,在 Python中,我可以这样做: if 'a' in ['a','b','c']: return 'Hi' 但在C中,我不确定它的等效功能是什么. 解决方法 使用 algorithm中的 std::find : std::vectorchar dynamic_array{'a','c'};auto exists = std::find(dynamic_array.begin(),dynamic_
例如,在 Python中,我可以这样做:

if 'a' in ['a','b','c']:
   return 'Hi'

但在C中,我不确定它的等效功能是什么.

解决方法

使用< algorithm>中的 std::find

std::vector<char> dynamic_array{'a','c'};
auto exists = std::find(dynamic_array.begin(),dynamic_array.end(),'a')
                  != dynamic_array.end();

如果你发现自己做了很多这样的事情,你可以创建一个函数:

template<typename Container,typename T>
bool contains(Container const& container,T const& value) {
    using std::begin;
    return std::find(begin(container),end(container),value)
               != end(container);
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读