C++系列-STL中搜索相关算法
STL中search相关算法
- 💢search相关算法
- 💢💢search算法举例
- 💢💢search_n算法举例
- 💢💢binary_search算法举例
- 💢 lower_bound
- 💢 upper_bound
- 💢 lower_bound和upper_bound
- 💢equal_range
纳兰性德《减字木兰花·相逢不语》
相逢不语,一朵芙蓉著秋雨。小晕红潮,斜溜鬟心只凤翘。
待将低唤,直为凝情恐人见。欲诉幽怀,转过回阑叩玉钗。
💢search相关算法
| 算法 | 描述 |
|---|---|
| search(beg1, end1, beg2, end2) | 在[beg1, end1) 范围内查找[beg2, end2)首次出现,查找成功,返回[beg1, end1)内第一次出现[beg2, end2)的位置,查找失败返回end1 |
| search(beg1, end1, beg2, end2, pred) | 使用pred代替==操作符执行search() |
| search_n(beg, end, n, val) | 在[beg, end)范围内查找val出现n次的字序列 |
| search_n(beg, end, n, val, pred) | 使用pred代替==操作符执行search_n() |
| binary_search(beg, end, val) | 使用二分法在[beg, end)范围内查找val,速度非常快。要求序列是有序的,否则结果未知,查找到后返回true,否则false |
| binary_search(beg, end, val, pred) | 使用pred代替==操作符执行binary_search() |
| lower_bound(beg, end, val) | 在[beg1, end1) 范围内查找第一个不小于val(>=val)的元素的迭代器,查找到后返回该元素的迭代器,否则返回序列的end(),因为内部是二分法实现的,需要保证是有序序列 |
| lower_bound(beg, end, val,pred) | 查找第一个不满足pred的元素对应的迭代器 |
| upper_bound(beg, end, val) | 在[beg1, end1) 范围内查找第一个大于val的元素的迭代器,查找到后返回该元素的迭代器,否则返回序列的end(),,因为内部是二分法实现的,需要保证是有序序列 |
💢💢search算法举例
👉 👉 👉
在下面的代码中,search(vec1.begin(), vec1.end(), vec2.begin(), vec2.end()),当在vec1{1, 33, 44, 2, 5, 55, 25, 44, 2, 7}中找到vec2{44, 2}时返回,在vec1中,有两处44,2子序列,只返回vec1中第一个44对应的迭代器。
search(vec1.begin(), vec1.end(), vec2.begin(), vec2.end(), [](int val1, int val2) -> bool {return val2 > val1;},在vec1{1, 33, 23, 2, 5, 55, 25, 44, 2, 7}中,寻找连续的子序列,对应的元素分别小于vec2{44, 5}中的44,5,vec1中的23,2分别小于44,5,故返回vec1中23所对应的迭代器。
code:
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;template<typename T>
void print_vector(const vector<T>& vec)
{for (auto i_vec : vec){cout << i_vec << " ";}cout << endl;
}void test01()
{vector<int> vec1 {1, 33, 44, 2, 5, 55, 25, 44, 2, 7};vector<int> vec2 {44, 2};vector<int>::iterator it = search(vec1.begin(), vec1.end(), vec2.begin(), vec2.end());if (it != vec1.end()){vector<int> vec3;vec3.assign(it, vec1.end());print_vector(vec3);}else{cout << "没找到" << endl;}
}void test02()
{vector<int> vec1 {1, 33, 23, 2, 5, 55, 25, 44, 2, 7};vector<int> vec2 {44, 5};// vec2中是一个整体,vec1从头开始搜索,当发现连续的元素满足和vec2的关系时,停止搜索vector<int>::iterator it = search(vec1.begin(), vec1.end(), vec2.begin(), vec2.end(), [](int val1, int val2) -> bool {return val2 > val1;});if (it != vec1.end()){vector<int> vec3;vec3.assign(it, vec1.end());print_vector(vec3);}else{cout << "没找到" << endl;}
}
void main()
{test01();test02();system("pause");
}result:
44 2 5 55 25 44 2 7
23 2 5 55 25 44 2 7
💢💢search_n算法举例
👉 👉 👉
在下面的代码中,search_n(vec1.begin(), vec1.end(), 2, 5),在vec1 {1, 33, 44, 2, 5, 5, 25, 44, 2, 7}中搜索连续的2个5,返回第一个5对应的迭代器。
search_n(vec1.begin(), vec1.end(), 3, 5, [](int val1, int val2) -> bool {return val1 > val2;}),在谓词中,第1个参数val1是vec1中的元素,第2个参数val2是5。
在vec1{1, 33, 23, 2, 18, 55, 25, 44, 2, 7}中搜索,连续3个元素满足分别大于5,18, 55, 25满足条件,则返回第一个元素18对应的迭代器。
code:
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;template<typename T>
void print_vector(const vector<T>& vec)
{for (auto i_vec : vec){cout << i_vec << " ";}cout << endl;
}void test01()
{vector<int> vec1 {1, 33, 44, 2, 5, 5, 25, 44, 2, 7};vector<int>::iterator it = search_n(vec1.begin(), vec1.end(), 2, 5);if (it != vec1.end()){vector<int> vec3;vec3.assign(it, vec1.end());print_vector(vec3);}else{cout << "没找到" << endl;}
}void test02()
{vector<int> vec1 {1, 33, 23, 2, 18, 55, 25, 44, 2, 7};vector<int>::iterator it = search_n(vec1.begin(), vec1.end(), 3, 5, [](int val1, int val2) -> bool {return val1 > val2;});if (it != vec1.end()){vector<int> vec3;vec3.assign(it, vec1.end());print_vector(vec3);}else{cout << "没找到" << endl;}
}
void main()
{test01();test02();system("pause");
}result:
5 5 25 44 2 7
18 55 25 44 2 7
💢💢binary_search算法举例
👉 👉 👉
binary_search是用二分法进行搜索的,序列应该是经过排序的,否则可能出现错误。
binary_search(vec1.begin(), vec1.end(), 2), 在vec1中搜索2,找到后返回true,否则为false。
binary_search(vec1.begin(), vec1.end(), 55, [](int val1, int val2)-> bool { return val1 > val2; });, 首先在vec1中搜索55,找到后,取vec1.begin()到55对应的迭代器区间中所有元素,与55进行pred中的规则判断,若区间中含有满足对比规则的元素,则返回 true ,反之返回 false。
code:
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;template<typename T>
void print_vector(const vector<T>& vec)
{for (auto i_vec : vec){cout << i_vec << " ";}cout << endl;
}void test01()
{vector<int> vec1 {1, 33, 44, 2, 5, 25, 7};cout << "vec1排序前:" << endl;print_vector(vec1);cout << "vec1排序后:" << endl;sort(vec1.begin(), vec1.end());print_vector(vec1);bool result = binary_search(vec1.begin(), vec1.end(), 2);if (result){cout << "找到了" << endl << endl;}else{cout << "没找到" << endl << endl;}
}void test02()
{vector<int> vec1 {1, 33, 23, 18, 55, 25, 44, 23, 7};cout << "vec1排序前:" << endl;print_vector(vec1);cout << "vec1排序后:" << endl;sort(vec1.begin(), vec1.end(),greater<int>());print_vector(vec1);// bool std::binary_search(_FwdIt _First, _FwdIt _Last, const _Ty & _Val, _Pr _Pred);// _Pred 为 bool (*)(const _Ty & _Ele, const _Ty & _Val)// 在bool binary_search(_FwdIt _First, _FwdIt _Last, const _Ty& _Val)的基础上,取_First至_Val迭代器区间的所有元素,// 与Val进行自定义规则的对比,若区间中含有满足对比规则的元素,则返回 true ,反之返回 false。bool result = binary_search(vec1.begin(), vec1.end(), 55, [](int val1, int val2)-> bool { return val1 > val2; });if (result){cout << "找到了" << endl;}else{cout << "没找到" << endl;}
}void main()
{test01();test02();system("pause");
}result:
vec1排序前:
1 33 44 2 5 25 7
vec1排序后:
1 2 5 7 25 33 44
找到了vec1排序前:
1 33 23 18 55 25 44 23 7
vec1排序后:
55 44 33 25 23 23 18 7 1
找到了
💢 lower_bound
- 🔥找到第一个可以插入 __val 的位置,并且不改变原有排序。
- 🔥找到的是大于等于目标数的位置。
👉 👉 👉
ForwardIterator lower_bound (ForwardIterator first, ForwardIterator last, const T& val);前两个分别为起始和结束迭代器,val是要进行对比的数值。
ForwardIterator lower_bound (ForwardIterator first, ForwardIterator last, const T& val, Compare comp); comp是自定义的比较规则。
前提是有序的情况下,lower_bound 返回指向第一个值不小于 val 的位置,也就是返回第一个大于等于val值的位置(通过二分查找)。
lower_bound(vec1.begin(), vec1.end(), 3); // – 排序后: 1 2 5 7 25 33 44, 第1个>=3的元素是5,返回其迭代器。
cout << "distance(vec1.begin(), iter1): " << distance(vec1.begin(), iter1) << endl; // distance用于计算两个迭代器之间的距离,从vec1.begin()到5对应的迭代器,距离是2。
lower_bound(vec1.begin(), vec1.end(), 6, [](int val1, int val2)-> bool { return val1 < val2; }),寻找序列中第一个不满足<6的元素。
code:
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;template<typename T>
void print_vector(const vector<T>& vec)
{for (auto i_vec : vec){cout << i_vec << " ";}cout << endl;
}void test01()
{vector<int> vec1 {1, 33, 44, 2, 5, 25, 7};cout << "vec1排序前:" << endl;print_vector(vec1);cout << "vec1排序后:" << endl;sort(vec1.begin(), vec1.end());print_vector(vec1);vector<int>::iterator iter1;vector<int>::iterator iter2;// 在动态数组中寻找 >=3 出现的第一个数 并以迭代器的形式返回iter1 = lower_bound(vec1.begin(), vec1.end(), 3); // -- 排序后: 1 2 5 7 25 33 44, 第1个>=3的元素是5,返回其迭代器// 在动态数组中寻找 >=7 出现的第一个数 并以迭代器的形式返回iter2 = lower_bound(vec1.begin(), vec1.end(), 30); // -- 排序后: 1 2 5 7 25 33 44, 第1个>=30的元素是33,返回其迭代器// distance用于计算两个迭代器之间的距离,从vec1.begin()到5对应的迭代器,距离是2cout << "distance(vec1.begin(), iter1): " << distance(vec1.begin(), iter1) << endl;// distance用于计算两个迭代器之间的距离,从vec1.begin()到33对应的迭代器,距离是5 cout << "distance(vec1.begin(), iter2): " << distance(vec1.begin(), iter2) << endl;
}void test02()
{vector<int> vec1 {2, 7, 18, 23, 25, 33, 44, 55};sort(vec1.begin(), vec1.end());cout << "\nvec1:" << endl;print_vector(vec1);vector<int>::iterator iter1;vector<int>::iterator iter2;// vec1的元素是2, 7, 18, 23, 25, 33, 44, 55// iter1, pred的条件是val1<val2, vec1中的元素小于val2,lower_bound返回的是不满足pred设定的条件第1个元素,// 那么应该找到第一个不满足小于6的元素,是7,则返回7对应的迭代器。iter1 = lower_bound(vec1.begin(), vec1.end(), 6, [](int val1, int val2)-> bool { return val1 < val2; });// 应该找到第一个不满足小于30的元素,是7,则返回33对应的迭代器。iter2 = lower_bound(vec1.begin(), vec1.end(), 30, [](int val1, int val2)-> bool { return val1 < val2; });if (iter1 == vec1.end()){cout << "没找到" << endl;}else{cout << *iter1 << endl;}if (iter2 == vec1.end()){cout << "没找到" << endl;}else{cout << *iter2 << endl;}
}
void main()
{test01();test02();system("pause");
}result:
vec1排序前:
1 33 44 2 5 25 7
vec1排序后:
1 2 5 7 25 33 44
distance(vec1.begin(), iter1): 2
distance(vec1.begin(), iter2): 5vec1:
2 7 18 23 25 33 44 55
7
33
💢 upper_bound
- 🍐找到最后一个可以插入 val 而不改变原来有序数组的排序位置。
- 🍐前提是有序的情况下,upper_bound 返回第一个大于–val值的位置(通过二分查找)。
- 🍐 用lower_bound类似。只是把lower_bound的 大于等于换成大于, pred是相同的用法。
👉 👉 👉
upper_bound(vec1.begin(), vec1.end(), 4)即找到序列中第一个大于4的位置。
upper_bound(vec1.begin(), vec1.end(), 4, [](int val, int serial)-> bool { return val < serial; }); _Pred(_Val, *_UMid)中的第1个参数是upper_bound中的第3个参数,本例中_Pred要求4<序列中的值,找到第一个满足的位置,应该为8。
code:
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;void test01()
{vector<int> vec1 = { 1, 4, 8, 18, 22, 34, 55 };vector<int>::iterator iter1;vector<int>::iterator iter2;// 在vec1中寻找>4的第一个数 返回其迭代器iter1 = upper_bound(vec1.begin(), vec1.end(), 4); // 大于4,则指向8// 在动态数组中寻找 >7 出现的第一个数 并以迭代器的形式返回iter2 = upper_bound(vec1.begin(), vec1.end(), 15); // 大于17,则指向18if (iter1 == vec1.end())cout << "未找到满足条件的元素" << endl;else{cout << "*iter1: " << * iter1 << endl; }if (iter2 == vec1.end())cout << "未找到满足条件的元素" << endl;else{cout << "*iter2: " << * iter2 << endl; }
}void test02()
{vector<int> vec1 = { 1, 4, 8, 18, 22, 34, 55 };vector<int>::iterator iter1;vector<int>::iterator iter2;// _Pred(_Val, *_UMid)中的第1个参数是upper_bound中的第3个参数,本例中_Pred要求4<序列中的值,找到第一个满足的位置,应该为8iter1 = upper_bound(vec1.begin(), vec1.end(), 4, [](int val, int serial)-> bool { return val < serial; }); if (iter1 == vec1.end())cout << "未找到满足条件的元素" << endl;else{cout << "*iter1: " << *iter1 << endl; }
}void main()
{test01();test02();system("pause");
}result:
*iter1: 8
*iter2: 18
*iter1: 8
💢 lower_bound和upper_bound
- 🥝 在没有pred参数的情况下,lower_bound是寻找第一个大于等于参数val的元素的位置,upper_bound是寻找第一个大于参数val的元素的位置。
- 🥝 有pred的情况下,lower_bound中pred的默认参数为_Pred(*_UMid, _Val),第1个是序列中的元素,第2个是lower_bound中的val参数。upper_bound中pred的默认参数为_Pred(_Val, *_UMid),第2个是upper_bound中的val参数,第2个是序列中的元素。
💢equal_range
- 🍋 返回pair类型,两个迭代器,第1个是lower_bound,第2个是upper_bound。
code:
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;template<typename T>
void print_vector(const vector<T>& vec)
{for (auto i_vec : vec){cout << i_vec << " ";}cout << endl;
}void test01()
{vector<int> vec1 {1, 2, 5, 7, 25, 33, 44};print_vector(vec1);pair<vector<int>::iterator, vector<int>::iterator> p1;// equal_range,返回一对迭代器,第1个是lower_bound(>=33),第2个是upper_bound(>33)p1 = equal_range(vec1.begin(), vec1.end(), 33); if (p1.first != vec1.end()){cout << *p1.first << endl;}else{cout << "lower_bound not found!" << endl;}if (p1.second != vec1.end()){cout << *p1.second << endl;}else{cout << "upper_bound not found!" << endl;}
}void main()
{test01();system("pause");
}result:
1 2 5 7 25 33 44
33
44
相关文章:
C++系列-STL中搜索相关算法
STL中search相关算法 💢search相关算法💢💢search算法举例💢💢search_n算法举例💢💢binary_search算法举例 💢 lower_bound💢 upper_bound💢 lower_bound和up…...
5.C++程序中的注释
我们来看上节所写的程序 #include <iostream> using namespace std;void prnt() //打印A {cout << "printA" << endl; }int main() {prnt();return 0; } 上面的程序中“//打印A”,表示说明当前函数是打印内容的函数,具体…...
com.kingbase8.util.KSQLException: ERROR: permission denied for table xxx
前言 在信创改造中,数据库替换为国产数据库是不可缺少的一部分。而可替换选项中多数选项无非是人大金仓和达梦数据库二选一。本文将介绍人大金仓在使用过程的问题以及解决办法。 问题 在使用人大金仓数据库后,程序运行报错 com.kingbase8.util.KSQLEx…...
开发小程序
由于之前购入的阿里云ECS放着落灰,碰巧又看到个有趣的项目,于是就做了个生成头像的小程序…由于第一次完整发布小程序,记录一下遇到的问题 小程序名称:靓仔创意头像 😂 关于小程序 接口请求,在开发过程中…...
JS考核答案
1.请简述var, let, const的区别? (1)块级作用域:块作用域由 { }包括,let和const具有块级作用域,var不存在块级作用域。块级作用域解决了ES5中的两个问题: 内层变量可能覆盖外层变量 用来计数的…...
高德地图2.0 绘制、编辑多边形覆盖物(电子围栏)
1. 安装 npm i amap/amap-jsapi-loader --save移步:官方文档 2. map组件封装 <script lang"ts" setup> import AMapLoader from amap/amap-jsapi-loader import { onMounted, ref } from vue import { propTypes } from /utils/propTypesdefineO…...
MySQL底层为什么选择用B+树作为索引
首先,我们来想想为什么这么多数据结构,为什么要用树这种数据结构? 众多的数据结构在逻辑层面可分为:线性结构 和 非线性结构。 线性结构有:数组、链表,基于它们衍生出的有哈希表(哈希表也称散…...
MATLAB系列05:自定义函数
MATLAB系列05:自定义函数 5. 自定义函数5.1 MATLAB函数简介5.2 在MATLAB中传递变量:按值传递机制5.3 选择性参数5.4 用全局内存分享数据5.5 在函数两次调用之间本地数据的存储5.6 函数的函数(function functions)5.7 子函数和私有函数5.8 总结 5. 自定义…...
C++速通LeetCode简单第20题-多数元素
方法一:暴力解法,放multiset中排序,然后依次count统计,不满足条件的值erase清除。 class Solution { public:int majorityElement(vector<int>& nums) {int ans 0;multiset<int> s;for(int i 0;i < nums.s…...
回收站永久删除的文件还能恢复吗?教你恢复技巧
在数字时代,电脑是我们工作、学习和娱乐的重要工具。然而,随着我们对电脑的频繁使用,误删文件的情况也时有发生。当我们在回收站中不小心永久删除了某个重要文件时,内心可能会充满焦虑和疑惑:这些文件还能恢复吗&#…...
Python Web 微服务架构全面解析与实战指南
Python Web 微服务架构全面解析与实战指南 目录 🏗️ 微服务基础概念 微服务架构与单体架构的对比微服务的优点与挑战 🔄 服务间通信 使用REST、gRPC或消息队列实现服务通信API网关的使用(如Kong、Traefik) 🔍 服务…...
SEAFARING靶场漏洞攻略
寻找漏洞 一,我们打开页面 第一个漏洞 xss漏洞 1.在登录页面显示有弹窗 第二个漏洞 sql注入漏洞 1.在输入框的地方输入-1 union select 1,2,3#我们来查看他的回显点 2.查看数据库表名 -1 union select 1,database(),3# 3.查看表名 -1 union select 1,2,group…...
ROS 编程入门的介绍
2.1 创建 ROS 功能包 ROS(Robot Operating System)是一种开源的机器人软件框架,广泛用于机器人开发中。通过使用 ROS,开发者可以轻松创建和管理机器人应用程序。在本节中,我们将介绍如何创建一个 ROS 功能包并实现一些…...
第十一章 抽象类与接口
一、抽象类和抽象方法 抽象类:使用abstract修饰的类 抽象方法:在类中没有方法体的方法,称为抽象方法,抽象方法用abstract修饰 抽象类中可以没有抽象方法,包含抽象方法的类必是抽象类 如果子类没有实现父类中的全部…...
请问企业的八大金刚系统是哪些?有什么共同点和区别?
我的理解的八大金刚包括:MES、ERP、WMS、OMS、CRM、SCM、SRM、PLM。 这些系统的主要功能及运用领域是哪些方面?他们互相之前有什么区别?选择时哪些是企业可能根据自身需求选择的必选项目或可选项目? 由于某些系统的必选性取决于企业的具体业…...
【入门】配置 Java 应用程序的完整指南
前言: Java 是一种广泛使用的编程语言,具备跨平台的特性,使得其应用程序可以在多种环境中高效运行。本文将介绍如何将 Java 应用程序从开发环境部署到生产环境,确保其能够稳定、稳定地运行运行。 确定运行环境 Java程序可以运行…...
flutter widget 设置GestureDetector点击无效
有可能是被上层的widget挡住了,虽然你看得到这个widget,但是操作不到。使用相对布局Stack要特别注意,这种布局会和Android一样,先写的布局放在下层,后写的,如果范围较大的话,会盖在之前的widget…...
基于SpringBoot的在线教育平台的设计与实现
文未可获取一份本项目的java源码和数据库参考。 选题的背景与意义: 随着互联网时代信息技术的不断发展,线下已经产生了很多IT技术的培训机构,但是价格却十分昂贵并且需要人们持续不断的去具体培训地点学习,因此更需要一个课程优…...
Django_Vue3_ElementUI_Release_004_使用nginx部署
1. nginx安装配置 1.1 下载nginx Download nginx 1.2 测试一下 1.3 进入nginx用命令操作 2. 部署 2.1 前端部署 2.1.1 修改nginx监听配置 …conf/nginx.conf http {... # 这里不进行修改server {listen 8010; # 监听 80 端口server_name 192.168.10.24; # 输入服务器 ip…...
Java抽象类的案例
抽象类的特点总结 不能实例化:抽象类不能直接创建实例。它只能被继承。即,你不能用 new 关键字创建抽象类的对象。 可以包含抽象方法:抽象类可以包含一个或多个抽象方法(没有方法体),这些方法必须在子类中…...
突破语言壁垒:Unity游戏翻译破局工具如何重构跨文化体验
突破语言壁垒:Unity游戏翻译破局工具如何重构跨文化体验 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 当你满怀期待地启动一款国际热门Unity游戏,却被满屏陌生文字阻挡了探索脚步…...
EmbeddingGemma-300m效果展示:多语言文本相似度计算实战
EmbeddingGemma-300m效果展示:多语言文本相似度计算实战 1. 引言 文本嵌入模型正在改变我们处理多语言内容的方式。想象一下,你有一个包含中文、英文、法文等多种语言的文档库,如何快速找到语义相似的内容?传统的关键词匹配方法…...
Web3D开发入门:5大引擎(Direct3D、OpenGL、UE、Unity、Three.js)选型指南
Web3D开发入门:5大引擎选型实战指南 当虚拟展厅、数字孪生和元宇宙应用席卷各行业时,选择合适的三维引擎成为开发者面临的首个关键决策。本文将带您深入剖析Direct3D、OpenGL、Unreal Engine、Unity和Three.js五大主流方案的技术特性与商业价值ÿ…...
霜儿-汉服-造相Z-Turbo模型推理优化:理解与避免神经网络中的耦合过度
霜儿-汉服-造相Z-Turbo模型推理优化:理解与避免神经网络中的耦合过度 不知道你有没有遇到过这种情况:想让AI画一个穿汉服的女孩,结果出来的图,发型和衣服总是一起“跑偏”。比如,你想生成一个“唐代齐胸襦裙”的造型&…...
FlowState Lab结合计算机网络概念:模拟智能网络配置助手
FlowState Lab结合计算机网络概念:模拟智能网络配置助手 1. 网络运维的痛点与AI解决方案 网络工程师每天都要面对复杂的网络环境和层出不穷的故障问题。传统排错流程往往需要工程师手动检查设备配置、分析日志信息、查阅技术文档,这个过程耗时耗力且容…...
告别配置迷茫!手把手教你用DaVinci Configurator配置Autosar NvM Block(含三种类型详解)
告别配置迷茫!手把手教你用DaVinci Configurator配置Autosar NvM Block(含三种类型详解) 在汽车电子开发中,非易失性存储(NVM)的配置往往是工程师们最头疼的环节之一。面对复杂的AUTOSAR存储协议栈…...
【Java边缘运行时部署终极指南】:20年专家亲授5大避坑法则与3步极速上线实战
第一章:Java边缘运行时部署全景认知与演进脉络Java在边缘计算场景中的运行时部署正经历从传统云中心化架构向轻量、自治、低延迟方向的深刻演进。早期Java应用依赖完整JDK和重量级容器(如Tomcat)部署于虚拟机或Kubernetes集群,难以…...
Freeswitch实战指南:核心命令与变量操作全解析
1. Freeswitch核心命令实战解析 第一次接触Freeswitch时,面对密密麻麻的命令行界面,我完全不知道从何下手。经过几个项目的实战积累,我发现掌握几个核心命令就能解决80%的日常需求。下面这些命令都是我踩过无数坑后总结出来的精华,…...
别再手动排版了!用LaTeX + TikZ 5分钟搞定高中数学试卷里的立体几何图
用LaTeXTikZ高效绘制数学试卷中的立体几何图形 数学试卷排版一直是教师们的痛点,尤其是立体几何图形的绘制。传统方法要么依赖专业绘图软件导出图片插入,要么直接在Word中用绘图工具勉强拼凑,不仅效率低下,修改起来更是噩梦。其实…...
Element UI图标命名背后的逻辑与最佳实践
Element UI图标命名体系的设计智慧与工程实践 在当今前端开发领域,UI组件库已成为提升开发效率的关键工具。Element UI作为Vue.js生态中最受欢迎的组件库之一,其图标系统的设计哲学和命名规范值得深入探讨。这套看似简单的图标命名体系背后,实…...
