Java详解LeetCode 热题 100(13):LeetCode 53:最大子数组和(Maximum Subarray)详解
文章目录
- 1. 题目描述
- 2. 理解题目
- 3. 解题思路
- 3.1 暴力法
- 3.1.1 O(n³) 暴力解法
- 3.1.2 O(n²) 优化的暴力解法
- 3.2 分治法
- 3.3 动态规划(Kadane算法)
- 3.3.1 动态规划基本思路
- 3.3.2 Kadane算法(空间优化版本)
- 3.4 前缀和方法
- 4. 具体实例解析
- 5. 代码优化与技巧
- 5.1 处理空数组和边界情况
- 5.2 优化内存使用
- 5.3 提前返回与特殊情况处理
- 6. 扩展题目和变种
- 6.1 找到最大子数组的具体位置
- 6.2 环形子数组的最大和
- 6.3 最大子矩阵和
- 7. 实际应用场景
- 7.1 金融领域
- 7.2 图像处理
- 7.3 生物信息学
- 7.4 时间序列分析
- 8. 面试技巧与注意事项
- 8.1 多种解法的对比
- 8.2 常见陷阱与错误
- 8.3 如何在面试中逐步构建解法
- 8.4 设计单元测试
- 9. 总结
- 9.1 解法比较
- 9.2 关键心得
- 10. 练习题目推荐
1. 题目描述
给你一个整数数组 nums
,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
子数组 是数组中的一个连续部分。
示例 1:
输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和最大,为 6。
示例 2:
输入:nums = [1]
输出:1
示例 3:
输入:nums = [5,4,-1,7,8]
输出:23
解释:连续子数组 [5,4,-1,7,8] 的和最大,为 23。
约束条件:
1 <= nums.length <= 10^5
-10^4 <= nums[i] <= 10^4
2. 理解题目
这个问题要求我们在给定的整数数组中找出一个连续的子数组,使得这个子数组内所有元素的和最大。注意以下几点:
- 必须是连续的子数组:我们不能跳过中间的元素。例如,在
[-2,1,-3,4]
中,我们不能选择[-2,4]
,因为它不是连续的。 - 子数组至少包含一个元素:即使所有元素都是负数,我们也必须选择至少一个元素。
- 我们要找的是最大和:如果有多个子数组具有相同的最大和,任选一个返回即可。
在示例1中:[-2,1,-3,4,-1,2,1,-5,4]
,最大和的连续子数组是 [4,-1,2,1]
,和为6。虽然我们可以看到数组中有更大的单个元素(如4),但题目要求的是子数组的和最大,而不是子数组中的最大元素。
3. 解题思路
对于最大子数组和问题,有多种解决方法,包括暴力法、分治法、动态规划和前缀和等方法。下面我们会详细介绍每种方法,并分析其时间复杂度和空间复杂度。
3.1 暴力法
暴力法是最直观的解决方案,它枚举所有可能的子数组,计算它们的和,然后找出最大值。
3.1.1 O(n³) 暴力解法
最原始的暴力方法是枚举所有可能的子数组,然后计算每个子数组的和。
算法步骤:
- 初始化一个变量
maxSum
用于保存最大子数组和,初始值为数组的第一个元素 - 使用两个嵌套循环来枚举所有可能的子数组的起点和终点
- 使用第三个循环计算每个子数组的和
- 如果当前子数组的和大于
maxSum
,则更新maxSum
- 返回
maxSum
Java 代码实现:
public class Solution {public int maxSubArray(int[] nums) {if (nums == null || nums.length == 0) {return 0;}int maxSum = nums[0]; // 初始化最大和为第一个元素int n = nums.length;// 枚举所有可能的子数组for (int i = 0; i < n; i++) { // 子数组的起始位置for (int j = i; j < n; j++) { // 子数组的结束位置int currentSum = 0;// 计算从i到j的子数组和for (int k = i; k <= j; k++) {currentSum += nums[k];}// 更新最大和maxSum = Math.max(maxSum, currentSum);}}return maxSum;}
}
时间复杂度分析:
- 外层循环执行 n 次
- 中层循环最多执行 n 次
- 内层循环最多执行 n 次
- 总时间复杂度:O(n³)
空间复杂度分析:
- 只使用了常数额外空间,空间复杂度为 O(1)
3.1.2 O(n²) 优化的暴力解法
上面的暴力方法可以进行优化,去掉最内层的循环。我们可以在计算子数组和时,利用之前计算的结果,而不是每次重新计算。
算法步骤:
- 初始化一个变量
maxSum
用于保存最大子数组和,初始值为数组的第一个元素 - 使用两个嵌套循环来枚举所有可能的子数组
- 对于每个起始位置 i,初始化
currentSum = 0
,然后向右扩展子数组 - 每次将新元素加入子数组时,更新
currentSum
并检查是否需要更新maxSum
- 返回
maxSum
Java 代码实现:
public class Solution {public int maxSubArray(int[] nums) {if (nums == null || nums.length == 0) {return 0;}int maxSum = nums[0]; // 初始化最大和为第一个元素int n = nums.length;// 枚举所有可能的子数组for (int i = 0; i < n; i++) { // 子数组的起始位置int currentSum = 0; // 从位置i开始的子数组的和for (int j = i; j < n; j++) { // 子数组的结束位置currentSum += nums[j]; // 将当前元素加入子数组// 更新最大和maxSum = Math.max(maxSum, currentSum);}}return maxSum;}
}
时间复杂度分析:
- 外层循环执行 n 次
- 内层循环最多执行 n 次
- 总时间复杂度:O(n²)
空间复杂度分析:
- 只使用了常数额外空间,空间复杂度为 O(1)
与 O(n³) 的方法相比,这个优化版本去掉了最内层的循环,通过累加的方式计算子数组的和,从而将时间复杂度降低到了 O(n²)。
3.2 分治法
分治法是"分而治之"的策略,它将问题分解为相似的子问题,解决子问题,然后将子问题的解组合起来。对于最大子数组和问题,我们可以将数组划分为左右两部分,分别求出左半部分的最大子数组和、右半部分的最大子数组和,以及跨越中点的最大子数组和,然后取三者中的最大值。
算法步骤:
- 将数组分成左右两半
- 递归地求解左半部分的最大子数组和
- 递归地求解右半部分的最大子数组和
- 求解跨越中点的最大子数组和(这部分必须包含中点左侧的元素和中点右侧的元素)
- 返回上述三个值中的最大值
Java 代码实现:
public class Solution {public int maxSubArray(int[] nums) {if (nums == null || nums.length == 0) {return 0;}return maxSubArrayHelper(nums, 0, nums.length - 1);}private int maxSubArrayHelper(int[] nums, int left, int right) {// 基本情况:只有一个元素if (left == right) {return nums[left];}// 找到数组的中点int mid = left + (right - left) / 2;// 递归计算左半部分的最大子数组和int leftMax = maxSubArrayHelper(nums, left, mid);// 递归计算右半部分的最大子数组和int rightMax = maxSubArrayHelper(nums, mid + 1, right);// 计算跨越中点的最大子数组和int crossMax = maxCrossingSum(nums, left, mid, right);// 返回三者中的最大值return Math.max(Math.max(leftMax, rightMax), crossMax);}private int maxCrossingSum(int[] nums, int left, int mid, int right) {// 计算包含中点左侧的最大子数组和int leftSum = 0;int leftMaxSum = Integer.MIN_VALUE;for (int i = mid; i >= left; i--) {leftSum += nums[i];leftMaxSum = Math.max(leftMaxSum, leftSum);}// 计算包含中点右侧的最大子数组和int rightSum = 0;int rightMaxSum = Integer.MIN_VALUE;for (int i = mid + 1; i <= right; i++) {rightSum += nums[i];rightMaxSum = Math.max(rightMaxSum, rightSum);}// 返回跨越中点的最大子数组和return leftMaxSum + rightMaxSum;}
}
时间复杂度分析:
- 分治法的时间复杂度可以用递归树来分析
- 在每一层递归中,我们需要 O(n) 的时间来计算跨越中点的最大子数组和
- 递归树的高度为 log(n)
- 总时间复杂度:O(n log n)
空间复杂度分析:
- 由于递归调用栈的深度为 log(n),空间复杂度为 O(log n)
3.3 动态规划(Kadane算法)
动态规划是解决最大子数组和问题的最优方法之一,特别是Kadane算法。Kadane算法的关键思想是:对于数组中的每个位置,计算以该位置为结束点的最大子数组和,然后从所有这些最大和中找出最大值。
3.3.1 动态规划基本思路
我们用 dp[i]
表示以第 i 个元素结尾的最大子数组和。那么,对于第 i 个元素,我们有两种选择:
- 将其加入到前面的子数组中(与前面的最大子数组和相加)
- 单独作为一个新的子数组的开始
所以,状态转移方程为:
dp[i] = max(dp[i-1] + nums[i], nums[i])
最终的最大子数组和就是所有 dp[i]
中的最大值。
算法步骤:
- 创建一个长度为 n 的 dp 数组,其中 dp[i] 表示以第 i 个元素结尾的最大子数组和
- 初始化 dp[0] =
相关文章:
Java详解LeetCode 热题 100(13):LeetCode 53:最大子数组和(Maximum Subarray)详解
文章目录 1. 题目描述2. 理解题目3. 解题思路3.1 暴力法3.1.1 O(n) 暴力解法3.1.2 O(n) 优化的暴力解法3.2 分治法3.3 动态规划(Kadane算法)3.3.1 动态规划基本思路3.3.2 Kadane算法(空间优化版本)3.4 前缀和方法4. 具体实例解析5. 代码优化与技巧5.1 处理空数组和边界情况…...
数字化驱动下的智慧物流与零售创新:全流程无人仓与定制开发开源AI智能名片S2B2C商城小程序的协同实践
摘要:本文以京东"全球首个全流程无人仓"为技术载体,结合"定制开发开源AI智能名片S2B2C商城小程序"的零售创新实践,探讨数字化技术如何重构物流与零售场景。研究揭示,京东通过全流程无人仓实现仓储效率提升4倍…...
从“工地砌砖”到“工厂造房”:模块化集成建筑(MiC建筑)如何重塑建筑业
在城市化进程加速与资源环境约束加剧的双重挑战下,建筑业正经历着一场深刻变革。模块化集成建筑(Modular Integrated Construction,简称MiC)以“工厂造楼”为核心理念,通过将建筑拆解为标准化模块并在工厂完成全流程预…...
idea出现tomcat不能正确部署的问题--解决方案
启动tomcat 报如下错误:(是因为已经在其他tomcat的中使用了这两个端口) 改成新端口 注意:不管是新增了页面,还是修改了页面,都需要重新部署项目,方法就是点击下面的绿色图标。否则新的页面操作不…...
编专利或委托他人编专利属于学术不端行为吗?
原文链接:编专利或委托他人编专利属于学术不端行为吗? 自己编专利或委托他人编专利属于学术不端吗? 5月4日,一篇题为《针对性护理干预在子宫肌瘤围手术期的情绪和生活质量临床应用效果》的论文,受到网友的广泛议论。…...
IEEE PRMVAI Workshop 17 | 智能医疗数据分析与应用
科研小伙伴们看过来!2025 年 IEEE 第三届模式识别、机器视觉和人工智能国际会议旗下的 Workshop 17——“Intelligent Health Monitoring and Inspection of Infrastructure(智能医疗数据分析与应用)” 超值得关注! 📅…...
网工实验——OSPF配置
网络拓扑图 配置 1.为每个路由器配置接口(略)(详细见RIP实验) 2.配置OSPF AR1 [AR1]ospf [AR1-ospf-1]area 1 [AR1-ospf-1-area-0.0.0.1]network 172.16.1.1 0.0.0.0 #精确配置网络,也可以像下面那条命令那样配置 …...
图灵码上爬第5题:屠龙刀--爬虫逆向
别问我,问我就是小菜鸡记录下学习成果,哈哈哈哈 第五题其实跟第四题的逻辑差不多,只不过加了点简单混淆的代码 题目: 请求参数经过特殊处理,适合JavaScript逆向入门练习 思路: 首先打开开发者工具&…...
Linux网络编程day7 线程池
线程池 typedef struct{void*(*function)(void*); //函数指针,回调函数void*arg; //上面函数的参数 }threadpool_task_t; //各子线程任务的结构体/*描述线程池相关信息*/struct threadpool_t{pthread_mutex_t lock; …...
【SpringMVC】详解cookie,session及实战
目录 1.前言 2.正文 2.1cookie与session概念 2.2返回cookie参数 2.3设置session 3.小结 1.前言 哈喽大家好吖,今天继续来给大家来分享SpringMVC的学习,今天主要带来的是cookie与session的讲解以及通过postman和fiddler来实战,废话不多…...
《Vuejs 设计与实现》第 4 章(响应式系统)( 上 )
目录 4.1 响应式数据和副作用函数 4.2 基本响应式数据实现 4.3 设计完善响应系统 4.4 分支切换与清理 4.5 嵌套的 effect 与 effect 栈 4.1 响应式数据和副作用函数 副作用函数是指那些产生副作用的函数 function effect() {document.body.innerText = hello vue3 }执行 …...
《社交应用架构生存战:React Native与Flutter的部署容灾决胜法则》
React Native和Flutter作为当下热门的跨平台开发框架,在社交应用开发领域各显神通。今天,我们深入探索它们在高可用架构中的部署与容灾策略。 React Native凭借其独特优势,在社交应用开发中拥有一席之地。它基于JavaScript和React࿰…...
K8s网络从0到1
K8s网络从0到1 前言 K8s是一个强大的平台,但它的网络比较复杂,涉及很多概念,例如Pod网络,Service网络,Cluster IPs,NodePort,LoadBalancer和Ingress等等。为了帮助大家理解,模仿TC…...
React Native基础环境配置
React Native基础环境配置 1.引言2.React-Native简介3.项目基础环境搭建1.引言 感觉自己掌握的知识面还是有点太窄了,于是决定看看移动端的框架,搞个react搭一个后端管理项目,然后拿react-native写个小的软件,试着找个三方上架一下应用市场玩玩。毕竟不可能一直在简历上挂一…...
k8s术语之DaemonSet
DaemonSet确保全部(或者一些)Node上运行一个Pod的副本。当有Node加入集群时,也会为它们新增一个Pod。当有Node从集群移除时,这些Pod也会被回收。删除DaemonSet将会删除它创建的所有Pod 使用DaemonSet的一些典型用法: …...
接口自动化测试框架详解(pytest+allure+aiohttp+ 用例自动生成)
🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快 近期准备优先做接口测试的覆盖,为此需要开发一个测试框架,经过思考,这次依然想做点儿不一样的东西。 接口测试是比较讲究效…...
Go:简洁高效,构建现代应用的利器
Go,又称 Golang,是由 Google 开发的一种开源编程语言。它以其简洁的语法、高效的性能以及强大的并发特性,在云计算、微服务、DevOps 等领域迅速崛起,成为构建现代应用的利器。本文将带你了解 Go 的魅力,探讨其核心特性…...
Minor GC与Full GC分别在什么时候发生?
一、Minor GC 触发条件 1.Eden区空间不足 • 核心机制:新对象优先分配在Eden区,当Eden区无法满足新对象分配时触发Minor GC。 示例: // 循环创建对象填满Eden区 for (int i 0; i < 1000000; i) {byte[] data new byte[1 * 1024]; // 持…...
Crawl4AI:高效的开源 Python 网页爬取与数据提取库
Crawl4AI:高效的开源 Python 网页爬取与数据提取库 在数据驱动的时代,网页爬取和数据提取是众多 AI 项目及语言模型性能提升的关键环节。Crawl4AI 作为一款开源的 Python 库,凭借强大且灵活的功能,致力于简化这一复杂工作流程。其全异步设计不仅大幅提升了处理速度,还增强…...
【目标检测标签转换工具】YOLO 格式与 Pascal VOC XML 格式的互转详解(含完整代码)
一、写在前面:为什么需要标签格式转换? 在目标检测任务中,不同的模型和标注工具使用的标签格式常常不同: YOLO 系列(YOLOv5/v8) 使用的是 .txt 格式,每行为一个目标,记录相对归一化…...
Redis最新入门教程
文章目录 Redis最新入门教程1.安装Redis2.连接Redis3.Redis环境变量配置4.入门Redis4.1 Redis的数据结构4.2 Redis的Key4.3 Redis-String4.4 Redis-Hash4.5 Redis-List4.6 Redis-Set4.7 Redis-Zset 5.在Java中使用Redis6.缓存雪崩、击穿、穿透6.1 缓存雪崩6.2 缓冲击穿6.3 缓冲…...
2025年渗透测试面试题总结-某步在线面试(题目+回答)
网络安全领域各种资源,学习文档,以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具,欢迎关注。 目录 一、操作系统相关问题总结与分析及扩展回答 1. Linux命令熟悉度 2. 查看进程的命令 3. 查看网络进程…...
网络化:DevOps 工程的必要基础(Networking: The Essential Foundation for DevOps Engineering)
李升伟 编译 理解网络化基础知识 你是否曾想过是什么真正让卓越的DevOps工程师与众人区别开来?答案是网络化。是的,对网络的基本理解不仅仅是有帮助的——它是绝对必要的。在当今以微服务、容器和分布式系统为主宰的互联互通世界中,对网络原…...
<template>标签的用法
一、原生的template标签的用法 <template> 是 HTML5 引入的一个标签,用于声明 HTML 片段,这些片段在页面加载时不会被渲染,但可以在运行时通过 JavaScript 实例化和使用。 基本用法 <template id"myTemplate"> <…...
【数据结构】——链表OJ(下)
前面我们已经刷了几道单链表的题目,下面我们继续看几道题目。 一、相交链表 这道题题目的要求是很好理解的,就是现在我们有两个链表,然后我们就相办法进行判断,这两个链表是否是相交的,那么链表的相交其实就是有没有共…...
笔试专题(十六)
文章目录 相差不超过k的最多数题解代码 最长公共子序列(一)题解代码 小红的口罩题解代码 春游题解代码 相差不超过k的最多数 题目链接 题解 1. 排序 滑动窗口 2. 为什么使用滑动窗口? 因为max-min < k,求这个区间内的数最…...
云原生应用全生命周期管理实战:从开发、部署到运维的一体化方案
📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 一、前言:应用交付正在被“云原生”重塑 随着企业IT架构从单体转向微服务,再到全面拥抱容器化与Kubernetes,应用的构建、部署、配置、监控、弹性与治理也正经历一场全方位的变革。传统的开发运维…...
图表制作-带背景色的柱状图
首先登录自己的账号,没有账号的可以注册一个。 登录之后,在左侧菜单栏找到图表制作-统计图。 点击新建统计图,点击柱状图-带背景色的柱状图。 初始会有一些演示数据,可以根据自己的需要进行修改。 如果觉得手动修改太麻烦…...
【Pandas】pandas DataFrame ewm
Pandas2.2 DataFrame Function application, GroupBy & window 方法描述DataFrame.apply(func[, axis, raw, …])用于沿 DataFrame 的轴(行或列)应用一个函数DataFrame.map(func[, na_action])用于对 DataFrame 的每个元素应用一个函数DataFrame.a…...
V 型球阀:多材质多驱动,精准适配复杂严苛工况-耀圣
V 型球阀:多材质多驱动,精准适配复杂严苛工况 在化工、矿业、环保等工业领域,带颗粒介质、料浆以及高腐蚀性介质的输送与控制一直是行业难题。普通阀门在这些复杂工况下,易出现磨损、腐蚀、控制失灵等问题,而 V 型球阀…...
使用C# ASP.NET创建一个可以由服务端推送信息至客户端的WEB应用(2)
接上文 使用C# ASP.NET创建一个可以由服务端推送信息至客户端的WEB应用(1) https://blog.csdn.net/coldwind811201/article/details/147607641 1. 更新NuGet包 升级NuGet包后,注意相应修改前面页面上的JS引用为相应新版本的jquery JS脚本 …...
Java响应实体【R】
R响应实体 响应实体R(Response Entity)具体作用说明?1、用与数据传输2、用于状态反馈3、指令与控制 普通响应实体优化后的R:高级响应实体类 响应实体R(Response Entity)具体作用说明? 1、用与数据传输 传输请求结果 :当客户端向…...
短视频矩阵系统批量剪辑模式开发详解,支持OEM
在短视频行业竞争激烈的当下,短视频矩阵系统通过批量剪辑功能实现高效内容生产,成为众多运营者的利器。本文将深入探讨短视频矩阵系统中几种常见批量剪辑模式的开发思路与实现方法,助力开发者构建功能强大的批量剪辑模块。 一、批量剪辑模式概…...
顺丰科技:从 Presto 到 Doris 湖仓构架升级,提速 3 倍,降本 48%
导读:顺丰科技引入 Doris 替换 Presto,在内部可视化数据自助分析工具丰景台场景广泛应用。目前,顺丰临时查询业务、丰景台报表业务的 Presto 场景已经 100% 切换到 Doris 集群中,日均查询量 100W。并实现 P95 性能提升近 3 倍&…...
使用 Cesium 构建 3D 地图应用的实践
CesiumJS 是一个功能强大的开源 JavaScript 库,能够帮助开发者快速构建高性能、高精度的 3D 地球和地图应用 。本文将介绍如何使用 Cesium 构建一个基本的 3D 地图应用,并加载自定义的 3D Tiles 模型。 初始化 Cesium Viewer 首先,在 Vue 的…...
公链钱包开发:技术逻辑与产品设计实践
公链钱包开发:技术逻辑与产品设计实践 ——2025年数字资产管理的范式革命与用户价值重构 一、公链钱包的核心理解:技术逻辑与用户价值的耦合 公链钱包不仅是存储数字资产的工具,更是用户与区块链生态交互的“超级入口”。其核心价值体现在三…...
mobile自动化测试-appium webdriverio
WebdriverIO是一款支持mobile app和mobile web自动化测试框架,与appium集成,完成对mobile应用测试。支持ios 和android两种平台,且功能丰富,是mobile app自动化测试首选框架。且官方还提供了mobile 应用测试example代码࿰…...
【Python开源】深度解析:一款高效音频封面批量删除工具的设计与实现
🎵 【Python开源】深度解析:一款高效音频封面批量删除工具的设计与实现 🌈 个人主页:创客白泽 - CSDN博客 🔥 系列专栏:🐍《Python开源项目实战》 💡 热爱不止于代码,热情…...
飞算 用到妙处 AI辅助编程 - 双击方法名,自动识别到上下文中很方便
1. 双击findtasktypedict方法。右侧箭头指向自动识别 2. 按照说的内容机型了修改...
msIT大模型推理迁移调优工具
msIT LLM大模型ATB推理精度工具 适用场景:大模型加速库推理精度分析工具能力:大模型推理精度工具msIT llm,提供基于加速库推理的精度调试工具,支持数据dump、精度比对、单算子预检、溢出检测、模型迁移等能力。 msIT LLM大模型…...
YOGA Air X ILL10(83CX)/YOGA 14 ILL10X(83LC)2025款恢复开箱状态原装出厂Win11系统OEM镜像
适用机型(MTM): 【83LC】链接:https://pan.baidu.com/s/1AwbFR9nccvyzS1pOCToMvA?pwdewjs 提取码:ewjs 【83CX】链接:https://pan.baidu.com/s/1wMRI8ETodVG59GBDVDLgQg?pwdn3nx 提取码:n3nx lenovo联想原装wi…...
使用Deployment部署运行Nginx和Apache服务
1.Deployment简介 : 在Kubernetes(k8s)中,Deployment 是一种核心控制器资源,用于管理无状态应用的声明式部署、扩展与更新。它通过定义应用的期望状态,由控制器自动维护实际状态与期望状态的一致性&#x…...
382_C++_在用户会话结束时,检查是否有其他会话仍然来自同一个客户端 IP 地址,没有连接状态设置为断开,否则为连接
之前出现的问题:重启管理机,工作机上面热备连接状态显示未连接 (此时是有一个工作机连接管理机的),所以正常应该是连接状态解决:根因分析: 重启管理机后,管理机给过来的cookie是空的,导致工作机同时存在两个管理机的session,在其中一个超时后,调用回调函数通知会话断开…...
【 Redis | 实战篇 短信登录 】
前言: 主要完成了基于Session实现登录,解决集群的Session共享问题,从而实现了基于Redis来实现共享Session登录 1.基于Session实现登录 1.1.发送短信验证码 步骤: 前端提交手机号 》校验手机号 》不符合返回错误信息࿰…...
AI(学习笔记第二课) 使用langchain进行AI开发
文章目录 AI(学习笔记第二课) 使用langchain进行AI开发学习内容:1. 使用背景2.创建python(pycharm community版)开发环境并连接deepseek2.1 创建python(pycharm community版)开发环境2.2 创建python工程2.3 写入初始py…...
如何查看某个文件中的特殊符号
Q:如何查看某个文件中的特殊符号,比如说是换行符之类的转义字符? 1,法1:使用cat -A cat -A filename可以看到-A本质上就是-vET,也就是 展示所有的字符,-v是显示非打印字符,这个需…...
venv环境里控制scapy版本和起trex v2.87
要在虚拟环境(venv)中控制Scapy版本并运行TRex v2.87,您可以按照以下步骤操作: 创建一个新的虚拟环境: python3 -m venv trex-env激活创建的虚拟环境。在Linux或macOS上: source trex-env/bin/activate在Wi…...
第五十四篇 AI与数据分析
一、AI数据分析就像做菜 想象你在厨房做一道新菜,AI数据分析的流程其实非常相似: 买菜(获取数据) 去市场挑选新鲜蔬菜 从Excel/数据库获取数据例:pd.read_csv(超市销售表.csv) 洗菜切菜(清洗数据&#x…...
C++面向对象编程入门:从类与对象说起(一)
C语言是面向过程,关注的是过程,分析出求解问题的步骤,通过函数调用逐步解决问题,而C面向的是对象,关注的是对象,将一件事拆解成多个对象,靠对象之间互交完成。 目录 类的定义 类的两种定义 …...
openwrt之UCI 增删改查(add/get/set /add_list...)
1,引入 UCI是openwrt的统一配置接口,所有的配置文件被存放在/etc/config/下,使用UCI工具操作具体可查询官网中的开发文章: [OpenWrt Wiki] The UCI systemhttps://openwrt.org/docs/guide-user/base-system/uciconifg <secti…...