当前位置: 首页 > news >正文

判断vector、string是否存在某个元素

1、string字符串中是否存在某个字符(char)

string中find()返回值是字母在母串中的位置(下标索引),如果没有找到,那么会返回一个特别的标记npos。(返回值可以看成是一个int型的数)

string sentence = "I am a bad girl";
char s = 'c';
if(string::npos == sentence.find(s)) cout << "不存在" << endl;

2、vector中是否存在某个元素

2.1 std::count()

最简单的方式是对vector中的指定元素进行计数,如果count不为零,表示该元素存在,那么std::count可以很容易实现。

vector<string> words = {"wk","xf","ot","je"};
string word = "wk";
if(count(words.begin(), words.end(), word)) cout << "Found" << endl;
else cout << "Not Found" << endl;

2.2 std::find()

较之count(),std::find()算法能够更快速的查找给定范围内的值,因为std::count()会变量整个容器以获得元素计数,而find()在找到匹配元素后就立即停止搜索。

vector<string> words = {"wk","xf","ot","je"};
string word = "wk";
if(find(words.begin(), words.end(), word)!=words.end()) cout << "Found" << endl;
else cout << "Not Found" << endl;

2.3 std::binary_search()

如果vector是有序的,那么可以考虑使用这种算法,如果在给定范围内找到元素,则返回true,否则返回false。该方式是采用二分法查找,时间复杂度为O(log(n)),速度比较快。

vector<string> words = {"wk","xf","ot","je"};
string word = "wk";
if(binary_search(words.begin(), words.end(), word)) cout << "Found" << endl;
else cout << "Not Found" << endl;
http://www.lryc.cn/news/279051.html

相关文章:

  • C语言--结构体详解
  • 外卖骑手与行人之间的非零和博弈
  • [AutoSar]基础部分 RTE 06 对runnable的触发和SWC的影响
  • 网络层协议及IP编址与IP路由基础华为ICT网络赛道
  • 基于stm32f4的蓝牙控制小车
  • 基于BP神经网络的租金预测
  • C语言学习记录—进阶作业(通讯录文件版本)
  • 深度学习笔记(四)——TF2构建基础网络常用函数+简单ML分类网络实现
  • GPT function calling v2
  • 【Golang】IEEE754标准二进制字符串转为浮点类型
  • 【开源项目】轻量元数据管理解决方案——Marquez
  • dirty file page
  • HTAP(Hybrid Transactional/Analytical Processing)系统之统一存储的实时之道
  • 【linux】tcpdump 使用
  • 数字图像处理常用算法的原理和代码实现详解
  • Pandas实战100例 | 案例 26: 检测异常值
  • C语言学习NO.11-字符函数strlen,strlen函数的使用,与三种strlen函数的模拟实现
  • Vue3+ts获取props的值并且定义props值的类型的方法。
  • EasyExcel 不使用科学计数发并以千分位展示
  • 【Python机器学习】SVM——调参
  • 网络传输(TCP)
  • MFC模拟消息发送,自定义以及系统消息
  • 并发,并行,线程与UI操作
  • react 6种方式编写样式
  • 计算机找不到msvcr100.dll的多种解决方法分享,轻松解决dll问题
  • 系分笔记数据库反规范化、SQL语句和大数据
  • php实现支付宝商户转账
  • 并发编程(十一)
  • vue3 指令详解
  • 数据科学竞赛平台推荐