C++_STL_2021.11.12
2021/11/12 17:10:44
本文主要是介绍C++_STL_2021.11.12,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
手动实现STL中的search_n算法,代码如下:
#pragma once #include <iostream> #include <algorithm> #include <string> #include <vector> using namespace std; template<typename ForwardIter, typename Integer, typename T> ForwardIter np_serach_n( ForwardIter first, ForwardIter last, Integer count, const T& value) { if (count < 0) return first; first = find(first, last, value); while (first != last) { ForwardIter cur = first; cur++; int n = count - 1; while (cur != last && n != 0 && *cur == value) { cur++; n--; } if (n == 0) return first; else first = find(cur, last, value); } return last; } template<typename ForwardIter, typename Integer, typename T, typename BinaryPred> ForwardIter np_serach_n( ForwardIter first, ForwardIter last, Integer count, const T& value, BinaryPred binary_pred) { if (count < 0) return first; while (first != last && !binary_pred(*first, value)) ++first; while (first != last) { ForwardIter cur = first; ++cur; Integer n = count - 1; while (cur != last && n != 0 && binary_pred(*cur, value)) { cur++; n--; } if (n == 0) return first; else { first = cur; while (first != last && !binary_pred(*first, value)) ++first; } } return last; }
调用方法:
// Neptune.cpp: 定义应用程序的入口点。 // #include "Neptune.h" #include "non_mutate.h" #include <functional> void test_np_search_n() { int count = 2; string number = "world"; vector<string> numbers{ "Hello", "world", "world", "I", "love", "you", "world" }; auto it = np_serach_n<decltype(numbers.cbegin()), decltype(count), decltype(number)>( numbers.cbegin(), numbers.cend(), count, number); if (it != numbers.cend()) { cout << "Find " << count << " " << number << " index is: " << it - numbers.cbegin(); } else { cout << "Can't find " << count << " " << number; } } void test_np_serach_n_predicat(int count = 2) { //int number = 4; //vector<int> data{ 1, 3, 4, 5, 2, 1, 7, 8, 9 }; std::string number("hellooo"); vector<decltype(number)> data {"hello", "world", "chris", "I", "love", "you"}; std::function<bool(decltype(*data.cbegin()), decltype(number))> Predicate; auto it = np_serach_n<decltype(data.cbegin()), decltype(count), decltype(number), decltype(Predicate)>( data.cbegin(), data.cend(), count, number, [](decltype(*data.cbegin()) a, decltype(number) b) -> bool { return b.length() - a.length() > 2; }); if (it != data.cend()) { cout << "Find " << count << " index is: " << it - data.cbegin(); } else { cout << "Can't find! "; } } int main() { test_np_search_n(); test_np_serach_n_predicat(); return 0; }
这篇关于C++_STL_2021.11.12的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11国产医疗级心电ECG采集处理模块
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南