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

【优选算法 | 二分查找】二分查找算法解析:如何通过二段性优化搜索效率

在这里插入图片描述

算法相关知识点可以通过点击以下链接进行学习一起加油!
双指针滑动窗口

在本篇文章中,我们将深入解析二分查找算法的核心原理。从基本概念到实际应用,带你了解如何利用二分查找高效定位元素,提升搜索效率。无论你是刚接触算法的新手,还是想优化代码性能的老手,二分查找都是你不可忽视的强大工具!

请添加图片描述

Alt

🌈个人主页:是店小二呀
🌈C/C++专栏:C语言\ C++
🌈初/高阶数据结构专栏: 初阶数据结构\ 高阶数据结构
🌈Linux专栏: Linux
🌈算法专栏:算法
🌈Mysql专栏:Mysql

🌈你可知:无人扶我青云志 我自踏雪至山巅 请添加图片描述

文章目录

    • 34. 在排序数组中查找元素的第一个和最后一个位置(重要)
    • 二段性(重要/必备知识)
      • 1.查找左端点
      • 2.循环判断条件
      • 3. left和right移动方式
      • 3.求中点操作
      • 4.总结二分模板
    • 69.x 的平方根
    • 35.搜索插入位置
    • 69.山脉数组的峰顶索引
    • 162. 寻找峰值
    • 153. 寻找旋转排序数组中的最小值
    • LCR 173. 点名

34. 在排序数组中查找元素的第一个和最后一个位置(重要)

题目】:34. 在排序数组中查找元素的第一个和最后一个位置

在这里插入图片描述

如果题目为"在排序数组中查找元素",很自然可以想到朴素二分查找,根据中间数值讨论,但是"朴素二分"不适合更有层度题目,比如说这道题目。

首先如果使用朴素二分单凭一个中间值,很难得知第一个和最后一个位置。如果出现全部是相同元素的情况,会导致时间复杂度降成同暴力解法般,对此我们应该借助"二段性"优化二分查找策略

算法思路

二段性(重要/必备知识)

在二分查找算法中,“二段性”通常指的是数组被分成两个部分进行查找,每次都根据某种条件进行判断、决定在哪一部分继续搜索。简单来说,二分查找通过将问题逐步缩小到两个子问题中的一个,从而高效地找到目标元素。

1.查找左端点

通过绘图分析数组中的元素与目标值(target)之间的关系,我们可以将数组划分为两部分:左侧部分包含所有小于目标值的元素,右侧部分则包含所有大于或等于目标值的元素。这一划分是基于二分性质进行的。

在这里插入图片描述

【细节处理】

关于这部分细节,属于二分查找容易导致死循环的问题所在。

2.循环判断条件

这里有两种循环判断条件,必须要选择第一种,而不是第二种。如果选择第二种会导致死循环。

第一种:while(left < right)

第二种:while(left <= right)

选择第一种理由

理由一】:

这里只能选择第一种while(left < right),否则就会死循环。比如left = mid 或者 right = mid,当你判断条件为left <= rightleft == right 一直为真,导致死循环

理由二】:

left ==right的时候,就是最终结构,无需判断。图中有三种情况佐证:有结果,全大于t,全小于t

在这里插入图片描述

3. left和right移动方式

通过二分法将数组划分为两部分。在此过程中,需要根据目标值与当前划分区域的关系来判断leftright的移动方式。

在这里插入图片描述

通过绘图分析,如果目标值位于左侧且mid落在左侧,则left应设置为mid,而不是mid + 1,以避免错过目标值;如果mid落在右侧,则由于目标值不在右侧,right应设置为mid - 1

同理可得,当目标位于右侧,如果mid落在右侧,则right应设置为mid,而不是mid - 1,以避免错过目标值;如果mid落在左侧,则left应设置为mid + 1,因为目标值不在左侧。

3.求中点操作

首先考虑到 right 可能会超过Max值,所以会先采用 left + (right - left) / 2。在二分查找中,求中点操作有两个方式,在不同场景选择适合的方式,否则容易导致死循环

在这里插入图片描述

第一种方式】: mid = left + (right - left) / 2,会导致mid落在左侧

第二种方式】:mid = left + (right - left + 1) / 2,会导致mid落在右侧

例如,求左端点时,如果left = midright = mid - 1,根据这两个变量的移动规律,若使用第一种方式(left = mid + 1),会导致死循环,因此应使用第二种方式(left = mid)。同理,求右端点时,若left = mid + 1right = mid,应根据相应的规则调整边界,避免死循环并确保正确找到右端点,选择第一种方式。

代码实现

class Solution {
public:vector<int> searchRange(vector<int>& nums, int target) {int left = 0, right = nums.size() - 1;int begin = 0;if(nums.size() == 0) return {-1,-1};//求解左端点while(left < right){int mid = left + (right - left)/2;if(nums[mid] < target) left = mid + 1;else right = mid;}if(target != nums[left]) return {-1,-1};else begin = left;left = 0,right = nums.size() - 1;//求解右端点while(left < right){int mid = left + (right - left + 1)/2;if(nums[mid] > target) right = mid - 1;else left = mid;}return {begin,left};}
};

4.总结二分模板

在这里插入图片描述

通过不断刷题,我们会发现很多题目都是相似的。如果忘记了某些常用模板,也可以通过上述方式重新推导。关键在于如何识别题目中的二分性质,从而将问题划分为两个区间。


69.x 的平方根

题目】:69. x 的平方根

在这里插入图片描述

算法思路

1.暴力查找

通过枚举从 0 到 x 之间的每个整数 i,判断是否满足条件:

这里不需要考虑是否枚举到 x / 2x / 2 + 1,因为一旦找到结果就直接返回,后续的情况不再进行判断。过多的区间研究不仅浪费时间,还容易出错。

  • 如果 i * i == x,直接返回 i
  • 如果 i * i > x,说明前一个数 i-1 的平方已经超过了 x,因此返回 i - 1

由于 i * i 可能会超过 int 的最大值,所以应使用 long long 类型来存储变量。

class Solution {
public:int mySqrt(int x) {// 使用 long long 来避免溢出long long i = 0;for (i = 0; i <= x; i++) {// 如果平方等于 x,返回 iif (i * i == x) return i;// 如果平方大于 x,返回 i - 1if (i * i > x) return i - 1;}// 为了确保所有路径有返回值return -1;}
};

2.二分查找

在这里插入图片描述

设x的平分根的最终结果为ret。分析ret左右两侧数据的特点,从而发现二段性。

在这里插入图片描述

代码实现

class Solution {
public:int mySqrt(int x){int left = 1, right = x;if(x < 1) return 0;//处理下边界情况while(left < right){long long mid = left + (right - left + 1)/2;if(mid * mid <= x) left = mid;else right = mid - 1;}return left;}
};

35.搜索插入位置

题目】:35. 搜索插入位置

在这里插入图片描述

在这里插入图片描述

插入位置是第一个大于目标值的数,或者是最后一个数据。如果当前的数大于或等于目标值,那么这里就是我们所需的二分区间。如果没有元素,在最后一个位置,特殊情况特殊处理。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

代码实现

class Solution {
public:int searchInsert(vector<int>& nums, int target) {int left = 0, right = nums.size() - 1;while(left < right){int mid = left + (right - left)/2;if(nums[mid] < target) left = mid +1 ;else right = mid;}if(nums[left] < target) return right + 1;else return right;}
};

这里需要判断下,如果达到最后一个位置情况(nums[left] < target


69.山脉数组的峰顶索引

题目】:69. 山脉数组的峰顶索引

在这里插入图片描述

算法思路

在这里插入图片描述

通过绘图分析元素之间的大小关系,从而确定二分法的划分区间。

代码实现

class Solution {
public:int peakIndexInMountainArray(vector<int>& arr) {int left = 0, right = arr.size()-1;while(left < right){int mid = left + (right - left + 1) / 2;if(arr[mid - 1] <= arr[mid]) left = mid;else right = mid - 1;}return left;}
};

【细节分析】

1.arr[mid - 1] <= arr[mid] 是否会越界?

arr[mid - 1] 中,mid 的最小值是 1,因为 mid = left + (right - left + 1) / 2,而 left 从 0 开始,mid 永远不会是 0。arr[mid - 1] 访问的是 mid 左边的元素,因此不会越界。

2.如果采用arr[mid + 1]后果

如果是 arr[mid + 1],那会导致在 mid 达到数组最后一个元素时越界,但是这种情况在这个算法中并没有发生,因为我们始终是在 leftright 的范围内进行查找,确保 mid + 1 不会超出界限。


162. 寻找峰值

题目】:162. 寻找峰值

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

解法一:暴力解法

在这里插入图片描述

解法二:滑动窗口

通过两个点的分析,如果arr[i]>arr[i+1],呈现下降趋势,可以判断左边一定有峰值,但是右边不一定有峰值,可能是直接到负无穷或者另起一峰。同理arr[i]<arr[i+1],呈现上升趋势,可以判断右边一定有峰值,但是左边不一定有峰值。

在这里插入图片描述

我们可以根据1,2种情况去分出二段性,就可以使用二分查找。

在这里插入图片描述

如果arr[mid] > arr[mid+1],则左侧一定有我们的结果,只需right等于mid,而arr[mid] < arr[mid+1],则右侧一定有我们的结果,left等于mid +1去查找。

代码实现

class Solution {
public:int findPeakElement(vector<int>& nums){int left = 0,rigth = nums.size() - 1;while(left < rigth){int mid = left + (rigth - left + 1)/2;if(nums[mid - 1] < nums[mid]) left = mid;else rigth = mid - 1;}return left;}
};

个人思考

关于left和right移动规律,需要通过绘图去分析走向。这里很好通过表示了目标值是否存在作为突破口,发现二段性。所以具体情况还是需要具体分析的。


153. 寻找旋转排序数组中的最小值

题目】:153. 寻找旋转排序数组中的最小值

在这里插入图片描述

示例 1:

输入:nums = [3,4,5,1,2]
输出:1
解释:原数组为 [1,2,3,4,5] ,旋转 3 次得到输入数组。

示例 2:

输入:nums = [4,5,6,7,0,1,2]
输出:0
解释:原数组为 [0,1,2,4,5,6,7] ,旋转 4 次得到输入数组。

解法一:暴力解法

暴力查找最小值,时间复杂度O(N)。暴力解法慢,是没有利用这个数组的特性,经过旋转的有序数组。

解法二:二分查看

画张曲线图,寻找二段性,以D点nums[n-1]为参照物,AB区域是严格大于D点,CD区域是小于等于D点的。

在这里插入图片描述

通过mid在某个区间如何移动,去推到两个变量的移动方式。

代码实现

class Solution {
public:int findMin(vector<int>& nums) {int left = 0,right = nums.size() - 1;int x =nums[right];while(left < right){int mid = left + (right - left)/2;if(nums[mid] > x) left = mid + 1;else right = mid;}return nums[left];}
};

【疑问:选择A点的值作为参照物】

那么x = nums[0],通过绘图和mid落点去推导left和right移动方式即可。


LCR 173. 点名

【题目】:LCR 173. 点名

在这里插入图片描述

1.常见解法

  1. 哈希表法
    创建一个大小为 n+1 的哈希表,遍历原始数组并将元素填入哈希表,然后检查哪个位置没有被填充,这就是缺失的数字。
  2. 直接遍历法
    直接遍历原数组,找到缺失的元素。
  3. 位运算法 (XOR)
    使用位运算(XOR)来抵消重复出现的数字,最终剩下的就是缺失的数字。
  4. 数学法 (高斯求和公式)
    利用等差数列的求和公式,计算从 0 到 n 的总和与数组中所有元素的和之间的差值,得出缺失的数字。

这些方法的时间复杂度都是 O(n),因此适合处理大规模数据。

2.二分查找

【思考:0 到 n-1,为什么长度是 n-1?这个问题常见于面试中,面试官可能会与你探讨是否还有其他解法。】

这里可以根据图下,发现二段性使用二分查找。

在这里插入图片描述

通过比较数值与对应下标的关系,作为二分法的判定标准,从而划分搜索区间。

class Solution {
public:int takeAttendance(vector<int>& records) {int left = 0,rigth = records.size() - 1;while(left < rigth){int mid = left + (rigth - left) / 2;if(records[mid] == mid) left = mid + 1;else rigth = mid;}if(records[left] == left) return left + 1;else return left;}
};

在这里插入图片描述
快和小二一起踏上精彩的算法之旅!关注我,我们将一起破解算法奥秘,探索更多实用且有趣的知识,开启属于你的编程冒险!

相关文章:

【优选算法 | 二分查找】二分查找算法解析:如何通过二段性优化搜索效率

算法相关知识点可以通过点击以下链接进行学习一起加油&#xff01;双指针滑动窗口 在本篇文章中&#xff0c;我们将深入解析二分查找算法的核心原理。从基本概念到实际应用&#xff0c;带你了解如何利用二分查找高效定位元素&#xff0c;提升搜索效率。无论你是刚接触算法的新手…...

AI与IT协同的典型案例

简介 本篇代码示例展示了IT从业者如何与AI协同工作&#xff0c;发挥各自优势。这些案例均来自2025年的最新企业实践&#xff0c;涵盖了不同IT岗位的应用场景。 一、GitHub Copilot生成代码框架 开发工程师AI协作示例&#xff1a;利用GitHub Copilot生成代码框架&#xff0c;…...

5.软考高项(信息系统项目管理师)-成本管理

成本管理非常重要&#xff0c;选择、计算考得非常多&#xff0c;必须要好好学。 过程、输入、工具及输出 过程名&#xff08;附作用&#xff09; 通俗解释 输入 工具和技术 输出 规划成本管理 为如何管理项目成本提供指南和方向 编制成本管理计划&#xff0c;这个计划主…...

前端:纯HTML、CSS和JS菜单样式

实现了一个多级折叠菜单系统,使用纯HTML、CSS和JavaScript(无任何框架) 一、二级菜单展开 1、实现效果 初始状态-展示全部一级菜单 选中共状态,一级标题选中共为蓝色背景色,二级标题选中共为蓝色文字,展开右侧图标为-,后缩状态右侧图标为+ 2、实现 ​​HTML结构​​ …...

案例篇:如何用tcpdump和Wireshark识别潜在威胁

无论是日常浏览网页、观看视频&#xff0c;还是企业开展线上业务、进行数据传输&#xff0c;都离不开网络的支持。然而&#xff0c;网络问题也时有发生&#xff0c;比如网络卡顿&#xff0c;相信大家都遇到过&#xff0c;那种等待页面加载的焦急心情&#xff0c;真的让人抓狂。…...

微信小程序开发中关于首屏加载、本地数据持久化的思考

本文将围绕小程序开发中首屏性能优化与本地存储持久化两大重要主题展开&#xff0c;结合实际项目经验&#xff0c;系统分析常见问题、优化方法与最佳实践&#xff0c;构建流畅且高效的小程序体验。 文章目录 前言一、什么是首屏加载&#xff1f;为什么重要&#xff1f;二、小程…...

媒资管理之视频管理

一&#xff1a;业务概述&#xff1a; 媒资管理这个模块是我负责开发的&#xff0c;主要的管理对象是视频&#xff0c;图片&#xff0c;文档等 包括文件的上传&#xff0c;视频的处理&#xff0c;文件的删除 &#xff08;在媒资管理界面&#xff0c;有个上传视频的按钮&#…...

windows程序转鲲鹏服务器踩坑记【持续更新中】

1.鲲鹏处理器和Intel处理器的区别 处理器/对比项IntelKunpeng厂家因特尔(美国)华为(中国)指令集X86架构ARM-V8架构与指令集- x86 CISC复杂指令集 - 单核性能强&#xff08;如至强8380主频3.8GHz&#xff09; - 三级缓存优化&#xff0c;支持DDR4-3200和Optane内存- ARMv8-A RI…...

【阿里云大模型高级工程师ACP习题集】2.6.用插件扩展答疑机器人的能力边界

习题集: 【单选题】在构建Agent系统时,使用Assistant API创建Agent时,若想让Agent具备查询员工信息和发送请假申请的功能,以下对instructions参数设置最合理的是( ) A. “你可以做任何事情” B. “你能查询员工信息和发送请假申请” C. “你是公司助手,功能有:1.查询员…...

程序进程多任务线程

1.程序 程序(program)是含有指令和数据的文件,被存储在磁盘或其他的数据存储设备中,也就是说程序是静态的代码。 2.进程 进程(process)是程序的一次执行过程,是系统运行程序的基本单位,因此进程是动态的。进程是操作系统资源分配和处理器调度的基本单位,拥有独立的代码、内部数…...

Finish技术生态计划: FinishRpc

finishRpc 简介 ​ 纯个人兴趣设计的项目: 因为失业在家摆烂 所以没事就想写点代码 本身也比较喜欢自己写一些好玩的demo 这个项目的设计完全是取悦自己又菜又有一个创造框架的梦想 可以用于提升框架设计思路以及实践一些常用技术的练习 可以用于校园中的练习 , 如果能对你有所…...

《商业世界的开源法则:协议选择与商业模式创新》

引言 在当今数字化时代&#xff0c;开源软件已成为技术生态系统中不可或缺的一部分。从Linux操作系统到Apache Web服务器&#xff0c;从MySQL数据库到React前端框架&#xff0c;开源项目支撑着全球大部分互联网基础设施和企业IT系统。然而&#xff0c;关于开源协议与商业使用之…...

Kubernetes》》k8s》》explain查 yaml 参数

在创建json 和yaml 时&#xff0c;我们可能不知道具体的参数该怎么写。同样 我们可以通过explain这个 命令来查看 每个参数具体的作用与写法 # 查看 pod类性有哪些参数 kubectl explain pod# 查看pod中 spec下面有哪些参数 kubectl explain pod.spec...

Kubernetes(k8s)学习笔记(三)--部署 Kubernetes Master

前文已经使用docker安装了kubeadm&#xff0c;因此本文使用kubeadm部署master节点。 一.先拉取必要的镜像库到本地。 在拉取之前&#xff0c;先配下镜像加速 sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-EOF {"registry-mirrors": [&qu…...

《数据结构之美--二叉树》

一&#xff1a;引言&#xff1a; 上次我们学习了栈和队列这两个数据结构&#xff0c;今天我们来学习一个新的数据结构–二叉树中的堆。 堆其实就是一种特殊的二叉树&#xff0c;具有二叉树的性质的同时&#xff0c;还具有其他的性质。 那么在学习堆之前还是先来了解一下树。 …...

Prompt Engineering 提示工程:释放大语言模型潜力的关键技术与实践指南

提示工程:释放大语言模型潜力的关键技术与实践指南 提示工程(Prompt Engineering)作为与大型语言模型(LLM)交互的核心技术,已成为AI应用开发的关键技能。本文将系统介绍提示工程的定义与发展历程,深入剖析其核心知识点,提供实用的设计框架与技巧,并通过丰富的实战案例展示…...

std::print 和 std::println

一、基本概念 std::print 和 std::println 是 C23 新增的格式化输出函数&#xff0c;旨在替代传统的 std::cout 链式调用。它们基于 std::format 实现&#xff0c;支持类型安全的格式化字符串&#xff0c;语法更简洁&#xff0c;性能更优15。 功能特点&#xff1a; 直接输出到…...

高压直流输电MATLAB/simulink仿真模型+说明文档

1.模型简介 本仿真模型基于MATLAB/Simulink&#xff08;版本MATLAB 2018Ra&#xff09;软件。建议采用matlab2018 Ra及以上版本打开。&#xff08;若需要其他版本可联系代为转换&#xff09; 使用一个传输功率为1000MW&#xff08;500 kV&#xff0c;2 kA&#xff09;直流互连…...

第十四章-PHP与HTTP协议

第十四章-PHP与HTTP协议 一&#xff0c;HTTP 协议详解 HTTP&#xff08;HyperText Transfer Protocol&#xff0c;超文本传输协议&#xff09;是互联网上应用最广泛的协议之一&#xff0c;用于客户端&#xff08;如浏览器&#xff09;与服务器之间的通信。它是 Web 技术的基石…...

【阿里云大模型高级工程师ACP学习笔记】2.6.用插件扩展答疑机器人的能力边界

一、学习目标 备考阿里云大模型高级工程师ACP认证,深入学习《2.6.用插件扩展答疑机器人的能力边界》这部分内容,主要期望达成以下目标: 理解智能体应用核心概念:理解智能体(Agent)应用的核心概念,包括其如何拓展大模型能力,突破传统答疑机器人局限。掌握构建Agent系统…...

用远程代理模式轻松实现远程服务调用,打开编程新大门

通过远程代理来实现一个简易的远程过程调用实例。带你打开新的大门。 Socket 远程代理服务案例 基于 Socket 的远程服务&#xff0c;我们需要完成以下步骤&#xff1a; 服务端实现&#xff1a;创建一个远程服务&#xff0c;通过 Socket 接受客户端请求并提供计算服务。 客户端…...

(001)Excel 快捷键

文章目录 时间 时间 当前日期&#xff1a;ctrl ; (分号)。当前时间&#xff1a;ctrl Shift ; (分号)。...

TMI投稿指南(二):投稿文章注意事项

文章结构&#xff1a; https://journals.ieeeauthorcenter.ieee.org/create-your-ieee-journal-article/create-the-text-of-your-article/structure-your-article/ 补充材料&#xff1a;准备补充材料 - IEEE 作者中心期刊 --- Prepare Supplementary Materials - IEEE Author…...

从困局到破局的AI+数据分析

从困局到破局的AI数据分析 困局&#xff1a;数据分析的四道高墙破局&#xff1a;AI赋能全流程数据分析远见&#xff1a;AI数据分析的革命性意义 数据是新时代的石油&#xff0c;人工智能是炼油厂。当两者强强联合&#xff0c;一场数据分析的革命正悄然发生。 多少次你面对Excel…...

12. RANSAC点云多平面拟合分割

本文看了博客RANSAC点云多平面拟合分割-CSDN博客的文章&#xff0c;该博客将多平面拟合分割讲的很详细了&#xff0c;这里只是作为笔记用。 1.RANSAC算法原理 三维平面拟合&#xff08;最小二乘法&#xff09; 具体实现见下面代码&#xff1a; def SVD(points):# 二维&#…...

Prompt

提示工程指南 | Prompt Engineering GuideGoogle 官方提示工程 (Prompt Engineering)白皮书 | 宝玉的分享https://www.geeksforgeeks.org/what-is-prompt-engineering-the-ai-revolution/Prompt Engineering for Reasoning ModelsPrompt Engineering with Reasoning Models 1.p…...

[特殊字符] SpringCloud项目中使用OpenFeign进行微服务远程调用详解(含连接池与日志配置)

&#x1f4da; 目录 为什么要用OpenFeign&#xff1f; 在cart-service中整合OpenFeign 2.1 引入依赖 2.2 启用OpenFeign 2.3 编写Feign客户端 2.4 调用Feign接口 开启连接池&#xff0c;优化Feign性能 3.1 引入OkHttp 3.2 配置启用OkHttp连接池 3.3 验证连接池生效 Feign最佳…...

迈瑞医疗:国际业务增长21.28% 发展中国家成重要增长引擎

4月28日&#xff0c;迈瑞医疗&#xff08;300760.SZ&#xff09;发布2024年年度报告。报告期内&#xff0c;公司实现营业收入367.26亿元&#xff0c;同比增长5.14%&#xff1b;实现归母净利润116.68亿元&#xff0c;同比增长0.74%&#xff1b;经营活动产生的现金流量净额124.25…...

「地平线」创始人余凯:自动驾驶尚未成熟,人形机器人更无从谈起

温馨提示&#xff1a;运营团队2025年最新原创报告&#xff08;共210页&#xff09; —— 正文&#xff1a; 近日&#xff0c;国内智驾芯片上市公司[地平线]创始人兼CEO余凯&#xff08;先生&#xff09;接受腾讯新闻访谈时&#xff0c;提到如今大火的人形机器人&#xff0c;核…...

R 语言科研绘图第 43 期 --- 桑基图-冲击

在发表科研论文的过程中&#xff0c;科研绘图是必不可少的&#xff0c;一张好看的图形会是文章很大的加分项。 为了便于使用&#xff0c;本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中&#xff0c;获取方式: R 语言科研绘图模板 --- sciRplothttps://mp.weixin.qq.c…...

SpringBoot应用原生或docker镜像容器集成Skywalking

相关组件及版本 序号 组件 版本 备注 1 skywalking-oap-server 8.9.1 2 elasticsearch 7.17.6 3 skywalking-ui 8.9.1 4 apache-skywalking-java-agent 8.15.0 一、JAR包方式部署服务 下载apache-skywalking-java-agent jar文件 使用如下名称执行 java \ -j…...

模板--进阶

1. 非类型模板参数 模板解决了两类问题 1控制数据类型 2控制某种设计逻辑 类域可以直接访问什么&#xff1f; 1static修饰的静态成员变量 2typedef定义的内嵌类型 3 内部类 下面我们就要引出一个模板的知识点----------再用类模板的时候从类模板里面去取东西的时候 要…...

PostgreSQL无法查看表中数据问题排查

在 PostgreSQL 中&#xff0c;恢复数据库后&#xff0c;使用 DBeaver 等工具可以看到数据库和表名&#xff0c;但无法查询到表中数据&#xff0c;可能是以下原因之一。以下是可能的原因和解决方法&#xff1a; 1. 恢复未完全成功 原因&#xff1a;数据库恢复过程中可能未完全成…...

实验研究 | 千眼狼高速摄像机驱动精密制造创新

研究背景 小模数齿轮作为精密制造领域的核心组件&#xff0c;以“结构紧凑、重量轻、精度高”等优势&#xff0c;广泛应用于航空航天、工业机器人、精密仪器、医疗设备、新能源和微电机等领域。传统抛光技术效率低、成本高、表面质量不足&#xff0c;电解等离子体抛光技术&am…...

AWS虚拟专用网络全解析:从基础到高级实践

导语 AWS虚拟专用网络是连接企业本地数据中心与AWS云环境的关键桥梁。本文将深入探讨AWS VPN的核心概念、配置方法、最佳实践以及常见问题解决方案,助您构建安全、可靠的混合云网络架构。 一、AWS VPN概述 1. 定义 AWS VPN是一种网络服务,允许用户通过加密隧道将本地网络…...

工业园区工厂企业数字IP广播应急呼叫对讲系统:数字IP广播极大提升工厂企业管理效率与应急响应效能

工业园区工厂企业数字IP广播应急呼叫对讲系统:数字IP广播极大提升工厂企业管理效率与应急响应效能 北京海特伟业科技有限公司任洪卓发布于2025年4月28日 在数字化转型浪潮下&#xff0c;IP应急广播呼叫对讲广播系统凭借其网络化、智能化、融合化、多元化等优势&#xff0c;已…...

我的HTTP和HTTPS

注释&#xff1a;本文章架构跟随小林coding&#xff0c;在此基础上加深个人理解 小林coding&#xff1a;https://xiaolincoding.com/network/2_http/http_interview.html HTTP基本概念 HTTP是什么&#xff1f; http的中文名是超文本传输协议&#xff0c;超文本就是html&…...

python_股票月数据趋势判断

目录 前置 代码 视频&月数据 前置 1 A股月数据趋势大致判断&#xff0c;做一个粗略的筛选 2 逻辑&#xff1a; 1&#xff09;取最近一次历史最高点 2&#xff09;以1&#xff09;中最高点为分界点&#xff0c;只看右侧数据&#xff0c;取最近一次最低点 3&#xf…...

计算机考研精炼 计网

第 19 章 计算机网络体系结构 19.1 基本概念 19.1.1 计算机网络概述 1.计算机网络的定义、组成与功能 计算机网络是一个将分散的、具有独立功能的计算机系统&#xff0c;通过通信设备与线路连接起来&#xff0c;由功能完善的软件实现资源共享和信息传递的系统。 …...

大数据应用开发和项目实战-Matplotlib

Matplotlib的介绍 Matplotlib 是 Python 的绘图库&#xff0c;它能让使用者很轻松地将数据图形化&#xff0c;并且提供多样化的输出格式。 Matplotlib 可以用来绘制各种静态&#xff0c;动态&#xff0c;交互式的图表。比如说散点图、柱状图等等。 Matplotlib的安装与…...

SQLMesh CLI 实战教程: 构建和维护数据转换管道的快速指南

在数据工程领域&#xff0c;构建和维护数据转换管道是一项复杂而关键的任务。SQLMesh 是一个强大的工具&#xff0c;可以帮助你简化这一过程。本文将带你快速了解如何使用 SQLMesh CLI 来构建和维护数据转换管道。本文的目标是在 30 分钟或更短的时间内&#xff0c;让你熟悉 SQ…...

行政区划代码

本文数据来源&#xff1a;中华人民共和国民政部 在平常数据研究和开发中&#xff0c;经常会用到行政区划代码。而行政区划代码的使用&#xff0c;因年份不同可能也不尽完全相同。故整理了1980年到2024年所有的行政区划代码。 这样不仅仅适用于研究区划代码的变更研究&#xf…...

Spring生命周期

在Spring框架中&#xff0c;Bean的生命周期指的是从Bean的创建到销毁的整个过程。这个过程包括了多个阶段&#xff0c;每个阶段都有特定的操作。下面是一个典型的Spring Bean生命周期的概述&#xff1a; 一. 实例化&#xff08;Instantiation&#xff09; 当Spring容器启动时&…...

前端连接websocket服务报错 Unexpected response code: 301

前端连接websocket服务报错 Unexpected response code: 301 引直连测试301重定向修改nginx配置 引 websocket后端服务正常&#xff0c;监听正常&#xff0c;可以通过简单的前端代码进行连接&#xff0c;但是通过nginx反向代理后报错Error during WebSocket handshake: Unexpec…...

C语言(5)—操作符详解

文章目录 一、操作符分类概览二、二进制与进制转换2.1 进制基本概念 三、原码、反码与补码3.1 基本概念 四、位操作符详解 一、操作符分类概览 C语言中的操作符可以分为以下几大类&#xff1a; 算术操作符&#xff1a;, -, *, /, % 移位操作符&#xff1a;<<, >>…...

ubuntu新增磁盘挂载

1. 确认新磁盘 使用 lsblk 命令查看系统中所有的块设备&#xff0c;找出新增的磁盘。 rootzzwl:~# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTS sda 8:0 0 60G 0 disk ├─sda1 8:1 0 …...

【计网】计算机网络的类别与性能

一、计算机网络的分类 计算机网络可以根据不同的标准进行分类。下面是两种常见的分类方法&#xff1a; 1.按照网络的作用范围进行分类 广域网 (WAN): 广域网覆盖的范围非常广泛&#xff0c;通常跨越城市、国家或甚至是全球。WAN主要用于连接地理位置相隔较远的计算机和网络设…...

Field访问对象int字段,对象访问int字段,通过openjdk17 C++源码看对象字段访问原理

在Java反射机制中&#xff0c;访问对象的int类型字段值&#xff08;如field.getInt(object)&#xff09;的底层实现涉及JVM对内存偏移量的计算与直接内存访问。本文通过分析OpenJDK 17源码&#xff0c;揭示这一过程的核心实现逻辑。 一、字段偏移量计算 1. Java层初始化偏移量…...

香橙派打包qt文件报错“xcb 插件无法加载”与“QObject::moveToThread”线程错误的解决方案

PyQt 报错总结&#xff1a;打包文件过程&#xff0c;“xcb 插件无法加载”与“QObject::moveToThread”线程错误的解决方案全解析 在使用 PyQt5 搭建图形界面时&#xff0c;打包文件的过程中出现的问题&#xff0c;真难绷&#xff0c;搞了半天。 Qt 平台插件 xcb 无法加载QOb…...

Flutter 学习之旅 之 flutter 作为 module ,在 Android 的界面中嵌入Flutter界面功能的简单整理

Flutter 学习之旅 之 flutter 作为 module &#xff0c;在 Android 的界面中嵌入Flutter界面功能的简单整理 目录 Flutter 学习之旅 之 flutter 作为 module &#xff0c;在 Android 的界面中嵌入Flutter界面功能的简单整理 一、简单介绍 二、在同一个布局中同时显示 Androi…...