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

C++编译期字符串处理

1、非修改序列算法这些算法不会改变它们所操作的容器中的元素。1.1 find 和 find_iffind(begin, end, value)查找第一个等于value的元素返回迭代器未找到返回end。find_if(begin, end, predicate)查找第一个满足谓词的元素。find_end(begin, end, sub_begin, sub_end)查找子序列最后一次出现的位置。vectorint nums {1, 3, 5, 7, 9}; // 查找值为5的元素 auto it find(nums.begin(), nums.end(), 5); if (it ! nums.end()) { cout found: *it endl; // 输出5 } // 查找第一个大于6的元素 auto it2 find_if(nums.begin(), nums.end(), [](int x) { return x 6; }); cout first 6: *it2 endl; // 输出7 // 查找子序列 vectorint sub {3, 5}; auto it3 find_end(nums.begin(), nums.end(), sub.begin(), sub.end()); if (it3 ! nums.end()) { cout subsequence starts at index: it3 - nums.begin() endl; // 输出1 }1.2 count 和 count_ifcount(begin, end, value)统计等于value的元素个数。count_if(begin, end, predicate)统计满足谓词predicate的元素个数。std::vectorint vec {1, 2, 3, 2, 4, 2}; int cnt std::count(vec.begin(), vec.end(), 2); // 计数2的个数结果为3 int even_cnt std::count_if(vec.begin(), vec.end(), [](int x) { return x % 2 0; }); // 偶数个数结果为41.3 for_each对范围内的每个元素应用一个函数std::vectorint vec {1, 2, 3, 4, 5}; std::for_each(vec.begin(), vec.end(), [](int x) { x * 2; // 将每个元素乘以2 }); // 现在vec变为{2, 4, 6, 8, 10}1.4 equal 与 mismatchequal(b1, e1, b2)判断两个范围[b1,e1)和[b2, b2(e1-b1))是否相等。mismatch(b1, e1, b2)返回两个范围中第一个不相等元素的迭代器对pair。vectorint a {1, 2, 3}; vectorint b {1, 2, 4}; vectorint c {1, 2, 3, 4}; // 比较a和b的前3个元素 bool is_equal equal(a.begin(), a.end(), b.begin()); cout a b? boolalpha is_equal endl; // 输出false // 查找a和c的第一个不匹配元素 auto mis mismatch(a.begin(), a.end(), c.begin()); if (mis.first ! a.end()) { cout mismatch: *mis.first vs *mis.second endl; // 无输出a和c前3元素相等 }1.5 all_of, any_of, none_of检查范围内元素是否全部、存在或没有满足条件的std::vectorint vec {2, 4, 6, 8}; bool all_even std::all_of(vec.begin(), vec.end(), [](int x) { return x % 2 0; }); // true bool any_odd std::any_of(vec.begin(), vec.end(), [](int x) { return x % 2 ! 0; }); // false bool none_negative std::none_of(vec.begin(), vec.end(), [](int x) { return x 0; }); // true2、修改序列算法这些算法会修改它们所操作的容器中的元素。2.1 copy 和 copy_ifcopy(begin, end, dest)将[begin, end)中的元素复制到dest开始的位置。copy_if(begin, end, dest, predicate)复制满足谓词的元素到dest。vectorint src {1, 2, 3, 4, 5}; vectorint dest(5); // 需预先分配足够空间 // 复制所有元素 copy(src.begin(), src.end(), dest.begin()); // dest: [1,2,3,4,5] // 复制偶数元素到新容器 vectorint evens; copy_if(src.begin(), src.end(), back_inserter(evens), [](int x) { return x % 2 0; }); // evens: [2,4]注意back_inserter(dest)会自动调用push_back无需提前分配空间。2.2 transform对范围内的每个元素应用一个函数并将结果存储在另一个范围内vectorint nums {1, 2, 3}; vectorint squares(3); // 计算平方单参数转换 transform(nums.begin(), nums.end(), squares.begin(), [](int x) { return x * x; }); // squares: [1,4,9] // 两容器元素相加双参数转换 vectorint a {1, 2, 3}; vectorint b {4, 5, 6}; vectorint sum(3); transform(a.begin(), a.end(), b.begin(), sum.begin(), [](int x, int y) { return x y; }); // sum: [5,7,9]2.3 replace、replace_if与 replace_copyreplace(begin, end, old_val, new_val)将所有old_val替换为new_val。replace_if(begin, end, predicate, new_val)替换满足谓词的元素。replace_copy(begin, end, dest, old_val, new_val)复制时替换元素不修改原容器。vectorint nums {1, 2, 3, 2, 5}; // 替换所有2为20 replace(nums.begin(), nums.end(), 2, 20); // nums: [1,20,3,20,5] // 替换大于10的元素为0 replace_if(nums.begin(), nums.end(), [](int x) { return x 10; }, 0); // nums: [1,0,3,0,5] // 复制时替换3为300原容器不变 vectorint res; replace_copy(nums.begin(), nums.end(), back_inserter(res), 3, 300); // res: [1,0,300,0,5]2.4 remove、remove_if 与 eraseremove(begin, end, value)将等于value的元素 “移动” 到容器末尾返回新的逻辑尾迭代器不实际删除元素需配合erase。remove_if(begin, end, predicate)移动满足谓词的元素到末尾。vectorint nums {1, 2, 3, 2, 4}; // 逻辑删除所有2移动到末尾 auto new_end remove(nums.begin(), nums.end(), 2); // nums: [1,3,4,2,2] // 物理删除真正移除元素 nums.erase(new_end, nums.end()); // nums: [1,3,4] // 结合lambda删除偶数 nums {1, 2, 3, 4, 5}; nums.erase(remove_if(nums.begin(), nums.end(), [](int x) { return x % 2 0; }), nums.end()); // nums: [1,3,5]2.5 unique移除范围内连续的重复元素返回新的逻辑结尾迭代器。通常与erase结合使用。std::vectorint vec {1, 1, 2, 2, 3, 3, 3, 4, 5}; auto last std::unique(vec.begin(), vec.end()); vec.erase(last, vec.end()); // vec变为{1, 2, 3, 4, 5}2.6 reverse反转范围内的元素顺序std::vectorint vec {1, 2, 3, 4, 5}; std::reverse(vec.begin(), vec.end()); // vec变为{5, 4, 3, 2, 1}2.7 rotate旋转范围内的元素使中间元素成为新的第一个元素std::vectorint vec {1, 2, 3, 4, 5}; std::rotate(vec.begin(), vec.begin() 2, vec.end()); // 以3为起点旋转vec变为{3, 4, 5, 1, 2}2.8 shuffle随机重排范围内的元素需要C11或更高版本#include random #include algorithm std::vectorint vec {1, 2, 3, 4, 5}; std::random_device rd; std::mt19937 g(rd()); std::shuffle(vec.begin(), vec.end(), g); // 随机打乱vec中的元素3、排序和相关算法3.1 sort、stable_sort 与 partial_sortsort(begin, end)对元素进行快速排序不稳定平均时间复杂度 O (n log n)。stable_sort(begin, end)稳定排序相等元素相对位置不变。partial_sort(begin, mid, end)部分排序使[begin, mid)为整个范围中最小的元素并排序。std::vectorint vec {5, 3, 1, 4, 2}; std::sort(vec.begin(), vec.end()); // 默认升序vec变为{1, 2, 3, 4, 5} std::sort(vec.begin(), vec.end(), std::greaterint()); // 降序vec变为{5, 4, 3, 2, 1} std::sort(vec.begin(), vec.end(), [](int a, int b) { return a b; }); // 升序自定义比较 std::vectorstd::pairint, int vec {{1, 2}, {2, 1}, {1, 1}, {2, 2}}; std::stable_sort(vec.begin(), vec.end(), [](const auto a, const auto b) { return a.first b.first; // 按first排序保持相等元素的相对顺序 }); std::vectorint vec {5, 3, 1, 4, 2, 6}; // 将最小的3个元素放在前面并排序 std::partial_sort(vec.begin(), vec.begin() 3, vec.end()); // 现在vec前三个元素是1, 2, 3后面是未排序的4, 5, 63.2 nth_element重新排列范围使得指定位置的元素等于排序后的元素并且左边的元素都不大于它右边的元素都不小于它std::vectorint vec {5, 3, 1, 4, 2, 6}; // 找到第三小的元素索引2 std::nth_element(vec.begin(), vec.begin() 2, vec.end()); // 现在vec[2]是3它左边的元素3右边的33.3 binary_search、lower_bound、upper_bound需在已排序的容器上使用binary_search(begin, end, value)判断value是否存在返回bool。lower_bound(begin, end, value)返回第一个不小于value的元素迭代器。upper_bound(begin, end, value)返回第一个大于value的元素迭代器。vectorint sorted {1, 3, 3, 5, 7}; // 必须先排序 // 判断3是否存在 bool exists binary_search(sorted.begin(), sorted.end(), 3); // true // 查找第一个3的元素 auto lb lower_bound(sorted.begin(), sorted.end(), 3); cout lower_bound index: lb - sorted.begin() endl; // 输出1 // 查找第一个3的元素 auto ub upper_bound(sorted.begin(), sorted.end(), 3); cout upper_bound index: ub - sorted.begin() endl; // 输出33.4 merge合并两个已排序的范围到新容器保持排序vectorint a {1, 3, 5}; vectorint b {2, 4, 6}; vectorint merged(a.size() b.size()); // 合并a和b均需已排序 merge(a.begin(), a.end(), b.begin(), b.end(), merged.begin()); // merged: [1,2,3,4,5,6]4、堆算法STL提供了将范围作为堆来操作的算法包括make_heap,push_heap,pop_heap,sort_heap等。std::vectorint vec {4, 1, 3, 2, 5}; std::make_heap(vec.begin(), vec.end()); // 构建最大堆vec变为{5, 4, 3, 2, 1} vec.push_back(6); std::push_heap(vec.begin(), vec.end()); // 将新元素加入堆vec变为{6, 4, 5, 2, 1, 3} std::pop_heap(vec.begin(), vec.end()); // 将最大元素移到末尾vec变为{5, 4, 3, 2, 1, 6} int max_val vec.back(); // 获取最大元素6 vec.pop_back(); // 移除最大元素 std::sort_heap(vec.begin(), vec.end()); // 将堆排序为升序序列vec变为{1, 2, 3, 4, 5}5、最小/最大值算法5.1 min 和 max返回两个值或初始化列表中的最小/最大值int a 5, b 3; int min_val std::min(a, b); // 3 int max_val std::max(a, b); // 5 auto min_of_list std::min({4, 2, 8, 5, 1}); // 1 auto max_of_list std::max({4, 2, 8, 5, 1}); // 85.2 min_element 和 max_element返回范围内的最小/最大元素的迭代器std::vectorint vec {3, 1, 4, 2, 5}; auto min_it std::min_element(vec.begin(), vec.end()); // 指向1 auto max_it std::max_element(vec.begin(), vec.end()); // 指向55.3 minmax_element (C11)同时返回范围内的最小和最大元素的迭代器std::vectorint vec {3, 1, 4, 2, 5}; auto minmax std::minmax_element(vec.begin(), vec.end()); // minmax.first指向1minmax.second指向56、数值算法在numeric中6.1 accumulate计算范围内元素的累加和或自定义操作#include numeric std::vectorint vec {1, 2, 3, 4, 5}; int sum std::accumulate(vec.begin(), vec.end(), 0); // 和初始值为0结果为15 int product std::accumulate(vec.begin(), vec.end(), 1, std::multipliesint()); // 乘积初始值为1结果为1206.2 inner_product计算两个范围的内积或自定义操作std::vectorint a {1, 2, 3}; std::vectorint b {4, 5, 6}; int dot std::inner_product(a.begin(), a.end(), b.begin(), 0); // 1*4 2*5 3*6 326.3 iota用连续递增的值填充范围std::vectorint vec(5); std::iota(vec.begin(), vec.end(), 10); // 填充为10, 11, 12, 13, 146.4 partial_sum计算部分和将结果存储在目标范围内std::vectorint src {1, 2, 3, 4, 5}; std::vectorint dst(src.size()); std::partial_sum(src.begin(), src.end(), dst.begin()); // dst变为{1, 3, 6, 10, 15}6.5 adjacent_difference计算相邻元素的差值将结果存储在目标范围内std::vectorint src {1, 2, 3, 4, 5}; std::vectorint dst(src.size()); std::adjacent_difference(src.begin(), src.end(), dst.begin()); // dst变为{1, 1, 1, 1, 1}7、其他7.1 generate用生成函数填充范围std::vectorint vec(5); int n 0; std::generate(vec.begin(), vec.end(), [n]() { return n; }); // 填充为0, 1, 2, 3, 47.2 generate_n用生成函数填充范围的开始n个元素std::vectorint vec(5); int n 10; std::generate_n(vec.begin(), 3, [n]() { return n; }); // 前三个元素为10, 11, 12后两个保持不变7.3 includes检查一个排序范围是否包含另一个排序范围的所有元素std::vectorint vec1 {1, 2, 3, 4, 5}; std::vectorint vec2 {2, 4}; bool includes std::includes(vec1.begin(), vec1.end(), vec2.begin(), vec2.end()); // true7.3 set_union, set_intersection, set_difference, set_symmetric_difference执行集合操作并集、交集、差集和对称差集std::vectorint v1 {1, 2, 3, 4, 5}; std::vectorint v2 {3, 4, 5, 6, 7}; std::vectorint result; // 并集 std::set_union(v1.begin(), v1.end(), v2.begin(), v2.end(), std::back_inserter(result)); // result为{1, 2, 3, 4, 5, 6, 7} // 交集 result.clear(); std::set_intersection(v1.begin(), v1.end(), v2.begin(), v2.end(), std::back_inserter(result)); // result为{3, 4, 5} // 差集 (v1 - v2) result.clear(); std::set_difference(v1.begin(), v1.end(), v2.begin(), v2.end(), std::back_inserter(result)); // result为{1, 2} // 对称差集 (v1 ∪ v2 - v1 ∩ v2) result.clear(); std::set_symmetric_difference(v1.begin(), v1.end(), v2.begin(), v2.end(), std::back_inserter(result)); // result为{1, 2, 6, 7}8、常见问题sort与stable_sort的区别sort采用快速排序实际是 introsort 算法不稳定相等元素的相对位置可能改变平均时间复杂度 O (n log n)。stable_sort采用归并排序稳定相等元素相对位置不变时间复杂度 O (n log n)但空间开销略大。为什么remove算法需要配合erase使用remove算法的原理是 “覆盖” 要删除的元素将保留的元素移到前面返回新的逻辑尾迭代器但不修改容器的实际大小。erase则通过迭代器范围真正删除元素修改容器大小。因此需结合使用container.erase(remove(...), container.end())。哪些算法需要容器是已排序的二分查找系列binary_search、lower_bound、upper_bound、集合算法set_intersection、set_union等、merge等这些算法依赖有序性实现高效操作如二分查找 O (log n)。

相关文章:

C++编译期字符串处理

1、非修改序列算法这些算法不会改变它们所操作的容器中的元素。1.1 find 和 find_iffind(begin, end, value):查找第一个等于 value 的元素,返回迭代器(未找到返回 end)。find_if(begin, end, predicate):查找第一个满…...

C++课后习题训练记录Day118

1.练习项目: 问题描述 小蓝最近在研究一种浮点数的表示方法:RR 格式。对于一个大于 0 的浮点数 dd,可以用 RR 格式的整数来表示。给定一个转换参数 nn,将浮点数转换为 RR 格式整数的做法是: 将浮点数乘以 2^n; 四舍…...

用脑波写周报:消极想法触发自动优化——软件测试工程师的认知革命

在快节奏的软件测试领域,周报不仅是工作记录的载体,更是效能优化的重要工具。传统的周报撰写往往耗时且易受主观情绪影响,导致关键问题被遗漏。而基于脑波技术的智能系统,通过实时捕捉测试工程师的脑电信号,将消极想法…...

Agentic AI时代来临:企业如何构建“数据挖掘-分析-决策”的端到端闭环?

2026年被视为人工智能从“技术探索”迈向“规模化商用”的关键分水岭。随着国务院《人工智能赋能新型工业化三年行动计划》的深入实施,行业级智能体应用的落地正在加速。中国信通院数据显示,预计到2027年,国内将有超过50%的企业完成生成式AI智…...

破解光伏项目管理困局!绿虫智能平台,串联全周期赋能数字化转型

在能源转型与数字化融合的浪潮下,光伏产业正加速崛起,成为改写能源格局的核心力量。但光伏项目全周期管理中,数据孤岛、流程割裂、成本失控等痛点日益凸显,不仅制约项目推进效率,更影响企业核心收益,成为产…...

UPF 商用部署:从核心网架构到场景落地的实践指南

在 5G 商用全面铺开的今天,UPF(用户数据面功能实体) 早已不再是藏在核心网里的技术名词,而是决定网络性能、业务体验与行业赋能能力的核心枢纽。作为 5G 核心网中唯一负责用户数据报文处理的网元,UPF 的部署策略直接影…...

导师严选! 降AIGC软件 千笔 VS WPS AI,全场景通用首选

在AI技术迅速发展的今天,越来越多的学生和研究人员开始借助AI工具提升论文写作效率。然而,随着学术审核标准的不断提高,AI生成内容的痕迹和重复率问题日益突出,成为影响论文通过率的关键因素。面对市场上种类繁多的降AI率和降重复…...

MySQL【索引上】

在我们学习的过程中,我们了解,索引绝对是 MySQL 优化中最核心、最常用、也最容易被误解的知识点。很多人只知道 “加索引能变快”,但不知道为什么快、什么时候该加、加了又有什么代价。这篇文章就从磁盘原理、数据组织、索引结构、聚簇 / 非聚…...

vue-django flask+uniapp小程序宠物美容服务预约机构商城服务中心_2ahjj

目录技术栈选型与分工核心功能模块拆分数据模型设计要点接口交互规范关键实现难点测试部署方案迭代优化方向项目技术支持可定制开发之功能创新亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作技术栈选型与分工 后端框架选择 Django或Fl…...

《创业之路》-910-商业的黑幕、丑陋、利益、自私等是都商业原本的特性,是本能,正是因为这些特性,坦诚和诚信才显得尤为重要,方显反本能的重要性性。

商业的底色是“黑”,所以诚信才是唯一的“光”很多人对商业世界有一种天真的误解,认为商业的本质是“双赢”和“美好”。 但如果你剥开那些精美的PPT、宏大的愿景和温情的品牌故事,直视商业的原初代码,你会发现:贪婪、…...

【数据结构】详解双向链表

目录 一,链表的分类 二,双向链表 1,双向链表的结构 2,双向链表的创建及功能实现 三,顺序表和双向链表的优缺点分析 一,链表的分类 链表有三种属性,每种属性有两种情况,总共有2…...

基于springboot丝绸之路”新疆自由行旅游网站设计与开发(源码+精品论文+答辩PPT等资料)

博主介绍:CSDN毕设辅导第一人、靠谱第一人、全网粉丝50W,csdn特邀作者、博客专家、腾讯云社区合作讲师、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交…...

英伟达NemoClaw平台或解决OpenClaw安全难题

英伟达CEO黄仁勋在周一的GTC主题演讲中宣布,公司已开发出企业级智能体平台NemoClaw。该平台基于热门开源框架OpenClaw构建,专为在企业自有硬件上本地构建和运行智能体而设计。这个新的开源平台本质上是集成了企业级安全和隐私功能的OpenClaw。根据英伟达…...

多例责任链模式

在本案例中我们模拟在618大促期间的业务系统上线审批流程场景像是这些一线电商类的互联网公司,阿里、京东、拼多多等,在618期间都会做一些运营活动场景以及提供的扩容备战,就像过年期间百度的红包一样。但是所有开发的这些系统都需要陆续的上…...

ROS2的核心概念E-参数

一、参数 参数是一种ROS系统中常用的数据传输方式。类似C编程中的全局变量,可以便于在多个程序中共享某些数据,参数是ROS机器人系统中的全局字典,可以在运行多个节点时共享数据。 二、参数的作用 在机器视觉识别时,有很多参数都…...

腾讯版「龙虾」Workbuddy上线当天,我用它搭了一套行业情报日报系统

写在前面最近 AI 圈最火的词大概是「龙虾」。OpenClaw 掀起了一波桌面 AI Agent 的热潮——不再是聊天窗口里你一句我一句的问答,而是让 AI 直接在你的电脑上干活:操作文件、执行脚本、联网搜索、交付结果。3 月 9 日,腾讯发布了 WorkBuddy&a…...

论文AI痕迹怎么消除?2026年最值得用的降AI率软件推荐

论文AI痕迹怎么消除?2026年最值得用的降AI率软件推荐 论文中的AI痕迹怎么才能消除干净?本文从AIGC检测原理出发,推荐2026年最值得使用的降AI率软件,附详细使用教程和效果对比。 论文AI痕迹怎么消除?2026年最值得用的降…...

数字临终关怀测试:临终病人AI陪伴系统的伦理边界‌

AI临终关怀系统的测试伦理新边疆随着人工智能技术在临终关怀领域的加速渗透,AI陪伴系统通过模拟逝者语音、分析患者情绪,提供情感支持,成为医疗数字化的重要应用。然而,这类系统涉及敏感生命数据与伦理决策,对软件测试…...

苹果公司称其即将到来的50周年庆典献礼是用户

就在苹果公司上周重大产品发布后不久,苹果公司CEO蒂姆库克分享了一封信函,纪念苹果公司成立50周年(1976年4月1日)这一即将到来的里程碑。看到苹果公司努力应对周年纪念这一概念确实很奇怪。这通常不是该公司的做法,因为…...

拒绝“镜像裸奔”:深度剖析 ACR 私有仓库鉴权机制与本地排障实战

🛡️ 拒绝“镜像裸奔”:深度剖析 ACR 私有仓库鉴权机制与本地排障实战 在云原生开发中,容器镜像仓库(如阿里云 ACR)是我们存放核心业务代码的“金库”。然而,很多开发者在将仓库状态改为 【私有 (Private)…...

2026年热门降AI率工具推荐!一键消除AI痕迹+稳过检测

2026年热门降AI率工具推荐!一键消除AI痕迹稳过检测 又到论文集中提交、自媒体内容批量产出的时间段,不少同学和创作者都在为一件事头疼:AI生成痕迹太重,内容被平台判定为低质量,要么论文打回修改,要么自媒体…...

图表替代文字降AI率不会?看完这篇5分钟学会

图表替代文字降AI率,这个思路我用了快三个月才真正摸清楚门道。一开始只知道「AI率高了」,然后满篇改词换句,改完检测还是62%。后来有人告诉我,先把能换成图表的内容换掉,再上工具处理剩下的文字,AI率一次就…...

JS中的Set 核心认知

1. Set基础用法Set 是 ES6 新增的集合类型,核心特点是:存储唯一值(无重复元素),元素可以是任意类型(基本类型 / 引用类型),且遍历顺序与插入顺序一致。你可以把它理解为:…...

xtuoj矩形

这道题的思路是:1.将数据排序、去重、统计次数2.分为正方形和普通矩形处理,其中普通矩形处理运用了二分求解的思想,通过枚举每一条边x,找到其对应的上值maxy与下值miny,则对这一x满足条件的y也就是矩形个数有right-lef…...

大数据管理与应用如何结合?做好大数据管理与应用五大步骤

面对电脑里堆积如山的销售记录、用户反馈,你是不是觉得头疼,不知从哪里看起?心里清楚这些数字有用,却不知道怎么让它发挥作用? 大数据管理与应用脱节,是很多企业实际遇到的问题。大数据管理是基础工作&…...

结合之前对 **SSE流式输出** 和 **多智能体编排** 的探索,现在我们来深入 **异步任务处理**

结合你之前对 SSE流式输出 和 多智能体编排 的探索,现在我们来深入 异步任务处理。这是构建高性能AI应用的关键技术,特别是在处理长时间运行的代码生成任务时。 一、为什么需要异步任务处理? 同步 vs 异步对比 #mermaid-svg-ZNiJHP02TGpa4eEa{font-family:"trebuchet…...

【独家原创】基于(BO)Bayes-Transformer多变量时序预测(多输入单输出)附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室👇 关注我领取海量matlab电子书和…...

python-flask大学生二手电子数码产品交易平台设计与实现 _39qu9

目录实现计划概述需求分析技术选型功能模块设计数据库设计前后端开发测试与部署扩展功能建议项目技术支持可定制开发之功能创新亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作实现计划概述 开发一个基于Python-Flask的大学生二手电子数…...

复杂三维山地环境下小龙虾优化算法COA求解多无人机动态避障路径规划研究,MATLAB代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室👇 关注我领取海量matlab电子书和…...

动静态库原理与ELF文件详解

1. 什么是库 所有的库,本质都是源文件对应的 .o 文件动静态库中不要包含 main 函数静态库: .a[linux]、.lib[windows]动态库:.so[linux]、.dll[windows] 2. 静态库 静态库(.a):程序在链接的时候把代码链接到可执行文件中&#xff…...