算法模型从入门到起飞系列——递归(探索自我重复的奇妙之旅)
文章目录
- 前言
- 一、递归本质
- 1.1 递归的要素
- 1.2 递归特点
- 二、递归&迭代
- 2.1 递归&迭代比较
- 2.2 递归&迭代如何实现相同功能
- 2.2.1 递归实现
- 2.2.2 迭代实现
- 2.2.3 性能对比
- 三、优雅的递归理解
- 3.1 阶乘计算分解
- 3.2 [DFS](https://blog.csdn.net/qq_38315952/article/details/146374720?spm=1001.2014.3001.5501)分解
- 四、尾递归优化(Tail Call Optimization, TCO)
- 4.1 尾递归优化概念
- 4.2 尾递归优化演示
- 五、哪些问题更适合递归解决
- 1. 数学问题
- 2. 分治算法
- 3. 树形结构遍历
- 4. 回溯算法
- 5. 动态规划问题
- 6. 解析嵌套结构
- 7. 递归关系明确的问题
- 献给读者
前言
在编程的世界里,递归是一种既神秘又强大的工具。它宛如一个魔法盒子,能够将复杂的问题简化为更小规模的相同问题,直至找到最基础、可以直接解决的情况。无论是优雅地遍历复杂的树形结构,还是巧妙地解开经典的汉诺塔谜题,递归都能以其独特的方式展现其非凡的魅力。
递归的核心在于函数直接或间接地调用自身,这一过程看似简单,实则蕴含着深邃的逻辑和无限的可能性。通过递归,我们可以构建出简洁而富有表现力的代码,使得解决方案看起来自然而直观。然而,正如任何强大的工具一样,递归也有其双刃剑的一面:如果使用不当,可能会导致程序陷入无限循环,或是消耗过多的系统资源,甚至引发栈溢出错误。
本书旨在深入探讨递归的概念、应用及其背后的设计哲学。我们将从最基本的原则出发,逐步揭开递归的神秘面纱,揭示其在算法设计、数据结构处理以及实际软件开发中的广泛应用。无论你是编程新手,渴望理解递归的基础知识;还是经验丰富的开发者,希望进一步掌握递归优化技巧,本书都将为你提供宝贵的见解和实用的指导。
让我们一同踏上这段探索递归奥秘的旅程,在不断的实践中体会其带来的乐趣与挑战,共同解锁编程艺术中这扇独特的门扉。准备好迎接这场自我重复的奇妙之旅了吗?前方等待着你的,是更加深刻的理解和无尽的创造可能。
一、递归本质
递归
是一种在编程和数学中使用的方法,它指的是一个函数或过程直接或间接地调用自身
。递归通常用于解决可以被分解
为更小的相同问题的问题。这种方法非常强大,但需要小心使用,因为它可能导致无限循环或其他错误,如果设计不当的话。
💡贴士:递归核心就是调用自己,自我分解,化繁为简。
1.1 递归的要素
- 基准情况(Base Case):这是递归过程中的终止条件,用来停止递归调用。没有有效的基准情况会导致无限递归,最终可能耗尽系统资源或导致栈溢出错误。
- 递归步骤(Recursive Step):这是将问题规模减小,并朝向基准情况前进的步骤。在这个过程中,函数会调用自己并传入较小规模的问题参数。
1.2 递归特点
-
自我调用
递归的核心特点是函数直接或间接地调用自身。通过这种方式,复杂的问题可以被分解为更小、更易管理的子问题,直到达到一个可以直接解决的基础情况(基准情况)。 -
基准情况(Base Case)
每个递归函数都必须定义至少一个基准情况,作为递归终止的条件。基准情况是递归过程中最简单的情况,不需要进一步递归来解决。缺乏有效的基准情况会导致无限递归,最终可能引发栈溢出错误。 -
递归步骤(Recursive Step)
在递归步骤中,问题被分解为一个或多个较小规模的相同问题,并通过再次调用递归函数来求解这些子问题。递归步骤的设计至关重要,它决定了递归过程能否逐步接近基准情况,从而正确终止。 -
空间复杂度高
每次递归调用都会在调用栈上创建一个新的帧,用于保存局部变量和返回地址等信息。因此,递归可能会消耗大量的内存,特别是在深度递归的情况下,这可能导致栈溢出错误。相比之下,迭代通常需要较少的额外空间。 -
可能存在性能开销
由于函数调用本身有一定的开销,包括参数传递、局部变量初始化以及控制权转移等,递归可能会比等效的迭代实现慢。此外,重复计算相同子问题的情况(如未优化的斐波那契数列计算)也可能导致效率低下。 -
提升代码可读性
对于某些类型的问题,如树遍历、图搜索算法和分治算法,使用递归可以使代码更加简洁明了,易于理解和维护。递归结构能够直观地反映问题的本质,使得解决方案看起来自然而优雅。 -
尾递归优化
一些现代编程语言支持尾递归优化(Tail Call Optimization, TCO
),在这种情况下,如果递归调用是函数执行的最后一步且不需保留当前调用的状态,则编译器或解释器可以优化该递归调用以减少栈空间的使用,甚至将其转换为迭代形式,从而提高效率并避免栈溢出风险。
了解这些特点有助于合理选择何时使用递归解决问题,并采取适当措施优化递归函数的表现。无论是为了提升代码的清晰度还是性能,掌握递归的特点都是编程技能中的重要一环。
二、递归&迭代
2.1 递归&迭代比较
特性 | 递归 | 迭代 |
---|---|---|
定义 | 函数直接或间接调用自身来解决问题 | 使用循环结构重复执行一段代码,直到满足特定条件 |
基准情况 | 必须明确至少一个终止条件(基准情况),以避免无限递归 | 通过循环条件控制终止,无需显式定义基准情况 |
代码风格 | 对于某些问题(如树遍历、分治算法)更加直观和简洁 | 通常需要手动管理循环变量和状态,代码可能较冗长但清晰 |
空间复杂度 | 每次递归调用都会在栈上创建一个新的帧,可能导致较高的内存消耗 | 空间效率高,因为只需要固定的额外空间来存储循环变量 |
性能 | 可能存在函数调用开销,特别是深度递归时可能导致栈溢出错误 | 通常比递归更高效,因为它避免了函数调用的额外开销 |
适用场景 | 天然适合处理具有自我相似性质的问题(如树形结构、图搜索等) | 更适合解决可以通过简单的循环来解决的问题 |
优化可能性 | 支持尾递归优化(部分语言),可以减少栈空间使用 | 不需要特殊的优化,但在某些情况下可能需要考虑循环不变量的优化 |
示例应用 | 阶乘计算、斐波那契数列、汉诺塔、快速排序、归并排序 | 阶乘计算、斐波那契数列、线性搜索、二分查找 |
2.2 递归&迭代如何实现相同功能
为了更清楚地理解递归和迭代如何实现相同的功能,我们可以以计算阶乘为例。阶乘n!定义为从1到n的所有正整数的乘积(0! = 1)。下面是使用递归和迭代两种方法来实现这一功能的例子。
2.2.1 递归实现
public class Factorial {// 递归方法计算阶乘public static int factorialRecursive(int n) {if (n == 0 || n == 1) {return 1;} else {return n * factorialRecursive(n - 1);}}public static void main(String[] args) {// 测试阶乘函数int number = 5; // 你可以更改这个值来测试不同的输入System.out.println(number + "! = " + factorialRecursive(number));}
}
2.2.2 迭代实现
public class Factorial {// 迭代方法计算阶乘public static int factorialIterative(int n) {if (n < 0) {throw new IllegalArgumentException("Number must be non-negative.");}int result = 1;for (int i = 2; i <= n; i++) {result *= i;}return result;}public static void main(String[] args) {// 测试阶乘函数int number = 5; // 你可以更改这个值来测试不同的输入try {System.out.println(number + "! = " + factorialIterative(number));} catch (IllegalArgumentException e) {System.out.println(e.getMessage());}}
}
2.2.3 性能对比
💡贴士:可以看出递归和迭代实现的效果一样,区别在递归会使用多次重复计算,比如计算5的阶乘会计算4的阶乘一直到1的阶乘,然后又从1的阶乘一个一个叠加上去,相当于走了一个来回,增加了很多开销。
三、优雅的递归理解
如果看到这里还没有理解递归的思想或者无法使用递归处理问题,那么接下来不要眨眼睛,见证奇迹的时刻就要到了。
👉👉👉 所有的递归思想都可以转化成n
和n-1
的状态关系。
三步走思想:
- 参数(和n有关)。
- 临界条件(数学归纳法中临界条件,这个是最远的状态,一般是当n = 1时的状态值)。
- 计算fn的公式。
3.1 阶乘计算分解
递归思想:
阶乘问题是最好理解的,可以直接分解成f(n) = f(n-1) * n
。那么给定方法
3.2 DFS分解
💡贴士:所有的递归问题都可以换成
fn
和fn-1
…之间的关系,只不过像DFS这种不是计算的具体的值,而是用的处理操作。需要仔细体会一下fn
和fn-1
之间的关系。
四、尾递归优化(Tail Call Optimization, TCO)
4.1 尾递归优化概念
尾递归优化(Tail Call Optimization, TCO
)是一种编译器或解释器优化技术,旨在优化尾递归调用,使其不会增加额外的栈帧。这意味着在某些情况下,尾递归可以被转换为等效的迭代代码,从而避免了栈溢出的风险并提高了性能。
尾递归是指一个函数在其执行的最后一步调用自身,并且这个递归调用是函数返回值的一部分。换句话说,如果递归调用是函数的最后一个操作,那么它就是一个尾递归调用。
在Java中,标准的JVM
并不直接支持尾递归优化(Tail Call Optimization, TCO
)。这意味着即使你的函数是尾递归的,JVM
也不会自动将其优化为迭代形式。然而,你可以通过手动将尾递归转换为迭代来避免栈溢出问题。
4.2 尾递归优化演示
尽管如此,理解如何编写尾递归函数以及如何手动进行优化是非常有用的。下面我们将展示一个尾递归的阶乘函数示例,并讨论如何手动将其转换为迭代形式。
public class Factorial {// 尾递归方法计算阶乘public static long factorialTailRecursive(long n, long accumulator) {if (n == 0) {return accumulator;} else {return factorialTailRecursive(n - 1, n * accumulator);}}public static void main(String[] args) {// 测试阶乘函数long number = 5; // 你可以更改这个值来测试不同的输入System.out.println(number + "! = " + factorialTailRecursive(number, 1));}
}
在这个例子中,factorialTailRecursive 函数使用了一个累积器 accumulator 来存储中间结果。每次递归调用时,它都会更新 n 和 accumulator 的值,直到达到基准情况(n == 0)。
由于Java不支持尾递归优化,我们可以手动将上述尾递归函数转换为等效的迭代形式:
public class Factorial {// 迭代方法计算阶乘public static long factorialIterative(long n) {long result = 1;for (long i = 2; i <= n; i++) {result *= i;}return result;}public static void main(String[] args) {// 测试阶乘函数long number = 5; // 你可以更改这个值来测试不同的输入System.out.println(number + "! = " + factorialIterative(number));}
}
虽然Java本身不支持尾递归优化,但可以通过使用辅助类或数据结构来模拟这种行为。以下是一个示例,展示了如何使用一个简单的栈来模拟尾递归优化:
import java.util.ArrayDeque;
import java.util.Deque;public class Factorial {// 辅助类用于模拟尾递归private static class FactorialTask {long n;long accumulator;FactorialTask(long n, long accumulator) {this.n = n;this.accumulator = accumulator;}}// 模拟尾递归优化的方法public static long factorialSimulatedTCO(long n) {Deque<FactorialTask> stack = new ArrayDeque<>();stack.push(new FactorialTask(n, 1));while (!stack.isEmpty()) {FactorialTask task = stack.pop();if (task.n == 0) {continue;} else if (task.n == 1) {return task.accumulator;} else {stack.push(new FactorialTask(task.n - 1, task.n * task.accumulator));}}return 1; // 基准情况}public static void main(String[] args) {// 测试阶乘函数long number = 5; // 你可以更改这个值来测试不同的输入System.out.println(number + "! = " + factorialSimulatedTCO(number));}
}
💡贴士:
尽管Java不支持尾递归优化,但我们可以通过以下几种方式来处理这个问题:
👉手动转换为迭代:将尾递归函数转换为等效的迭代形式。
👉使用辅助类模拟:利用栈或其他数据结构来模拟尾递归的过程,从而避免栈溢出。
五、哪些问题更适合递归解决
1. 数学问题
阶乘计算:计算一个数的阶乘是一个经典的递归问题。
斐波那契数列:斐波那契数列中的每一项是前两项之和,非常适合用递归来实现。
最大公约数(GCD):欧几里得算法通过递归方式求解两个数的最大公约数。
2. 分治算法
归并排序:将数组分成两半,分别对每一半进行排序,然后合并结果。
快速排序:选择一个基准元素,将数组分为比基准大和比基准小的两部分,分别对这两部分进行排序。
二分查找:在一个有序数组中查找某个值,每次将搜索范围缩小一半。
3. 树形结构遍历
二叉树遍历:包括前序遍历、中序遍历和后序遍历等。
多叉树遍历:对于任意深度的多叉树,递归遍历是一种直观且高效的解决方案。
图的深度优先搜索(DFS):递归地访问每个相邻节点,直到所有节点都被访问过。
4. 回溯算法
八皇后问题:找到所有可以在棋盘上放置八个皇后而不互相攻击的方案。
迷宫问题:从起点开始,尝试每一条可能的路径,直到找到出口或所有路径都已尝试完毕。
组合和排列问题:生成一组元素的所有可能组合或排列。
5. 动态规划问题
虽然动态规划问题通常可以通过迭代来解决,但在某些情况下,递归结合记忆化(Memoization)可以简化问题的解决过程:
背包问题:给定一组物品,每个物品有一个重量和一个价值,在限定总重量的前提下,如何选择物品使得总价值最大。
最长公共子序列(LCS):找到两个序列的最长公共子序列。
6. 解析嵌套结构
解析表达式树:例如,解析算术表达式时,可以将其表示为一棵树,并通过递归方式对其进行求值。
解析JSON/XML数据:这些数据格式通常包含嵌套的对象和数组,递归方法可以方便地处理这种嵌套结构。
7. 递归关系明确的问题
汉诺塔问题:经典的递归问题,涉及将一系列盘子从一个柱子移动到另一个柱子。
字符串操作:例如,反转字符串、检查回文等,这些问题往往可以通过递归方式进行简单而直观的实现。
献给读者
💯 计算机技术的世界浩瀚无垠,充满了无限的可能性和挑战,它不仅是代码与算法的交织,更是梦想与现实的桥梁。无论前方的道路多么崎岖不平,希望你始终能保持那份初心,专注于技术的探索与创新,用每一次的努力和进步书写属于自己的辉煌篇章。
🏰在这个快速发展的数字时代,愿我们都能成为推动科技前行的中坚力量,不忘为何出发,牢记心中那份对技术执着追求的热情。继续前行吧,未来属于那些为之努力奋斗的人们。
亲,码字不易,动动小手,欢迎 点赞 ➕ 收藏,如 🈶 问题请留言(评论),博主看见后一定及时给您答复,💌💌💌
相关文章:
算法模型从入门到起飞系列——递归(探索自我重复的奇妙之旅)
文章目录 前言一、递归本质1.1 递归的要素1.2 递归特点 二、递归&迭代2.1 递归&迭代比较2.2 递归&迭代如何实现相同功能2.2.1 递归实现2.2.2 迭代实现2.2.3 性能对比 三、优雅的递归理解3.1 阶乘计算分解3.2 [DFS](https://blog.csdn.net/qq_38315952/article/deta…...
Netty源码—1.服务端启动流程二
大纲 1.服务端启动整体流程及关键方法 2.服务端启动的核心步骤 3.创建服务端Channel的源码 4.初始化服务端Channel的源码 5.注册服务端Channel的源码 6.绑定服务端端口的源码 7.服务端启动流程源码总结 5.注册服务端Channel的源码 (1)注册服务端Channel的入口 (2)注册…...
Python OCR文本识别详细步骤及代码示例
光学字符识别(OCR)是将图像中的文字转换为可编辑文本的技术。在Python中,我们可以利用多种库实现OCR功能。本文将详细介绍使用Tesseract和EasyOCR进行文本识别的步骤,并提供完整的代码示例。 一、OCR简介 OCR(Optical…...
springmvc 框架学习
什么是 SpringMVC 框架 Spring MVC 是 Spring 框架的核心模块之一,基于 Java Servlet API 构建的 Web 层解决方案。它实现了 MVC 设计模式(Model-View-Controller),专为开发灵活、松耦合的 Web 应用程序而设计。 在控制层框架历…...
学习threejs,构建THREE.ParametricGeometry参数化函数生成几何体
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️THREE.ParametricGeometry1…...
【华为OD-E卷 - 单词接龙 100分(python、java、c++、js、c)】
【华为OD-E卷 - 单词接龙 100分(python、java、c、js、c)】 题目 单词接龙的规则是: 可用于接龙的单词首字母必须要前一个单词的尾字母相同; 当存在多个首字母相同的单词时,取长度最长的单词,如果长度也相…...
美团Leaf分布式ID生成器使用教程:号段模式与Snowflake模式详解
引言 在分布式系统中,生成全局唯一ID是核心需求之一。美团开源的Leaf提供了两种分布式ID生成方案:号段模式(高可用、依赖数据库)和Snowflake模式(高性能、去中心化)。本文将手把手教你如何配置和使用这两种…...
性能测试过程实时监控分析
性能监控 前言一、查看性能测试结果的3大方式1、GUI界面报告插件2、命令行运行 html报告3、后端监听器接入仪表盘 二、influxDB grafana jmeter测试监控大屏1、原理:2、linux环境中influxDB 安装和配置3、jmerer后端监听器连接influxDB4、linux环境总grafana环境搭…...
【工具类】Java的 LocalDate 获取本月第一天和最后一天
博主介绍:✌全网粉丝22W,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…...
Eclipse 创建 Java 类
Eclipse 创建 Java 类 引言 Eclipse 是一款功能强大的集成开发环境(IDE),被广泛用于 Java 开发。本文将详细介绍如何在 Eclipse 中创建 Java 类,包括配置开发环境、创建新项目、添加类以及编写类代码等步骤。 配置 Eclipse 开发环境 1. 安装 Eclipse 首先,您需要在您…...
Centos编译升级libcurl
Centos编译升级libcurl 下载最新版源码包安装编译依赖配置编译选项如果报错:通过 EPEL 仓库安装手动源码编译安装 如果报错:安装Brotli 开发库 如果报错:方法一:安装 libpsl-devel 依赖通过 EPEL 仓库安装重新运行 configure 方…...
蓝桥杯第九天 2022 省赛 第 4 题 最少刷题数
太多坑了,考虑不全只能过50%,有两种特殊情况 public static void main(String[]args) {Scanner scan new Scanner(System.in);int n scan.nextInt();int a[] new int [100005];int b[] new int [100005];for(int i 0;i<n;i)a[i] scan.nextInt()…...
3D点云数据处理中的聚类算法总结
1.欧式聚类: 基于点的空间距离(欧几里得距离)来分割点云,将距离较近的点归为同一簇。 欧式聚类需要的参数:邻域半径R,簇的最小点阈值minPts,最大点数阈值maxPts。 实现效率: O(n * log n) 实现…...
配置本机监控
配置本机监控 1、安装zabbix-agent 2、编辑zabbix-agent配置文件 zabbix-agent工作模式: 主动模式 被动模式 这两行配置都是指定监控服务器的地址 被动模式下,zabbix server的地址 主动模式下,zabbix server的地址 指定被监控端的名称&…...
基于python的Flask模块化设计与蓝图的妙用——打造轻量化Web应用
基于python的Flask模块化设计与蓝图的妙用——打造轻量化Web应用 前言 如果你刚开始学习Flask,可能会遇到这样的困惑:当项目功能越来越多,代码都堆在一个.py文件里,不仅难维护,还容易冲突。别担心!本文将用…...
历年云南大学计算机复试上机真题
历年云南大学计算机复试机试真题 在线评测:传送门:pgcode.cn 喝饮料 题目描述 商店里有 n 中饮料,第 i 种饮料有 mi 毫升,价格为 wi。 小明现在手里有 x 元,他想吃尽量多的饮料,于是向你寻求帮助&#x…...
Python 线程池
Python 线程池 flyfish 线程池的概念 线程池是一种多线程处理形式,它预先创建了一定数量的线程,这些线程会被保存在一个线程池中。当有新的任务提交时,线程池会从池中取出一个空闲的线程来执行该任务;若池中没有空闲线程&#…...
【Linux】Bash是什么?怎么使用?
李升伟 整理 什么是 Bash? Bash(Bourne Again Shell)是一种 命令行解释器(Shell),广泛用于 Unix 和 Linux 操作系统。它是 Bourne Shell(sh) 的增强版,提供了更多的功能…...
蓝桥杯day2:解码异或 后的数组
一、题意 未知 整数数组 arr 由 n 个非负整数组成。 经编码后变为长度为 n - 1 的另一个整数数组 encoded ,其中 encoded[i] arr[i] XOR arr[i 1] 。例如,arr [1,0,2,1] 经编码后得到 encoded [1,2,3] 。 给你编码后的数组 encoded 和原数组 arr …...
R语言软件配置(自用)
①输入R: The R Project for Statistical Computing ②点击进入Cran镜像网页,选择清华大学镜像,选择自己合适的版本下载即可(以我电脑windows为例)。 ③点击base或者install R for the first time,然后选择Download R-4.4.3 for windows&…...
基于deepseek的智能语音客服【第二讲】后端异步接口调用封装
本篇内容主要讲前端请求(不包含)访问后端服务接口,接口通过检索知识库,封装提示词,调用deepseek的,并返回给前端的全过程,非完整代码,不可直接运行。 1.基于servlet封装异步请求 为…...
LEDNet总结
LEDNet:联合低光增强和暗光去模糊 1、暗光增强和去模糊可以单独处理,但是合并效果不理想。 研究问题的背景:光线不足 可见度颜色失真 最小快门速度有限 长时间曝光引起运动模糊 低光运动模糊同时存在 存在问题:暗光增强后运动模…...
线性规划的标准形式
标准形式的定义 目标函数:最大化线性目标函数 其中,x 是决策变量向量,c 是目标系数向量。 约束条件:等式形式约束 A x b, 其中,A 是约束系数矩阵,b 是常数项向量。 变量非负约束: 。 因此…...
xxl-job 执行器端服务器的简单搭建
xxl-job 执行器端服务器的简单搭建 先讲一下我们平时怎么使用 xxl-job 的,再引出背后是如何实现的。 我觉得对于一款成功的框架来说,好用,是非常重要的一个特性。 框架要便于接入,便于使用。对于用户来说,不要有太多…...
数字化企业可能会用到的系统有哪些?
你是否也曾像我一样,对这些问题充满疑问: 在企业数字化转型的浪潮中,究竟会涉及哪些系统? 这些系统又分别在何种情境下被投入使用? 如果你也有这样的疑问,那么这篇文章或许能为你答疑解惑。 为了给你一…...
【Linux】:守护进程化
朋友们、伙计们,我们又见面了,本期来给大家带来守护进程相关的知识点,如果看完之后对你有一定的启发,那么请留下你的三连,祝大家心想事成! C 语 言 专 栏:C语言:从入门到精通 数据结…...
在 web 部署 YOLOv8目标检测(Django+html)
本文介绍如何将自己训练好的模型在网页上进行应用,使用 Django html 进行部署,能够对视频和图像进行识别,并显示到页面上,下面是一个效果: 上 传 和另外 7 个页面 - 个人 - Microsoft Edge 2025-03-13 21-52-06 下面进…...
程序员学商务英语之Making Business Calls
Dialogue-1 Reaching Somebody By Telephone电话找人 A: What do you think the secrect to success is? 你认为成功的秘诀是什么? B: Hold on to your dreams. 坚持你的梦想。 A: May I speak to your boss, Mr. Wong? 请你的老板,王先生接电话?…...
java项目之基于ssm的少儿编程在线培训系统(源码+文档)
项目简介 少儿编程在线培训系统实现了以下功能: 用户信息管理: 用户信息新增 用户信息修改 教师信息管理: 教师信息添加 教师信息删除 教师信息修改 课程信息管理: 课程信息添加 课程信息修改 课程信息删除 课程类型管理&…...
【初学者】Python语言中有没有指针类型?
李升伟 整理 在Python语言中,没有像C或C那样的显式指针类型。Python的设计哲学强调简洁和易读,因此它隐藏了许多底层的细节,包括指针。 不过,Python中的变量可以被视为对对象的引用。当你创建一个对象并将其赋值给一个变量时&am…...
RG-S3760应用协议配置
RG-S3760应用协议配置 1. dhcp 服务配置 提问:如何在设备上开启dhcp 服务,让不同VLAN 下的电脑获得相应的IP 地址? 回答: 步骤一:配置VLAN 网关IP 地址,及将相关端口划入相应的VLAN 中 S3760#con t S…...
C++基础 [八] - list的使用与模拟实现
目录 list的介绍 List的迭代器失效问题 List中sort的效率测试 list 容器的模拟实现思想 模块分析 作用分析 list_node类设计 list 的迭代器类设计 迭代器类--存在的意义 迭代器类--模拟实现 模板参数 和 成员变量 构造函数 * 运算符的重载 运算符的重载 -- 运…...
skywalking微服务链路追踪
是什么? skywalking是一个优秀的国产开源框架,2015年由个人吴晟(华为开发者)开源 , 分布式链路追踪就是将一次分布式请求还原成调用链路,将一次分布式请求的调用情况集中展示,比如各个服务节点…...
K8S学习之基础三十七:prometheus监控node资源
Prometheus v2.2.1 编写yaml文件,包含创建ns、configmap、deployment、service # 创建monitoring空间 vi prometheus-ns.yaml apiVersion: v1 kind: Namespace metadata:name: monitor-sa# 创建SA并绑定权限 kubectl create serviceaccount monitor -n monito…...
Web 小项目: 网页版图书管理系统
目录 最终效果展示 代码 Gitee 地址 1. 引言 2. 留言板 [热身小练习] 2.1 准备工作 - 配置相关 2.2 创建留言表 2.3 创建 Java 类 2.4 定义 Mapper 接口 2.5 controller 2.6 service 3. 图书管理系统 3.1 准备工作 - 配置相关 3.2 创建数据库表 3.2.1 创建用户表…...
1221. 四平方和 -蓝桥杯真题-哈希函数思想
原题链接:1221. 四平方和 - AcWing题库 四平方和定理,又称为拉格朗日定理: 每个正整数都可以表示为至多 44 个正整数的平方和。 如果把 00 包括进去,就正好可以表示为 44 个数的平方和。 比如: 对于一个给定的正整…...
为什么要学习人工智能(AI)?—— 未来已来,AI引领时代变革
未来已来,AI引领时代变革 在这个日新月异的时代,人工智能(AI)正以不可阻挡之势重塑着我们的世界。从教育的深耕细作到科研的突破创新,从行政的效率提升到管理的智慧化转型,AI技术如同一股强大的潮流&#x…...
Markdig:强大的 .NET Markdown 解析器详解
在现代开发中,Markdown 已经成为了一种广泛使用的轻量级标记语言,特别是在文档、博客和内容管理系统中,Markdown 为开发者提供了快速、简洁的格式化文本方式。而在 .NET 生态中,Markdig 是一款非常强大的 Markdown 解析器…...
云计算迁移革命:企业如何摆脱“单一云”锁定,构建自主云未来?
一场价值690亿美元的行业地震 2023年,博通(Broadcom)以690亿美元完成对VMware的收购,这不仅是企业IT历史上的一次天价并购,更在全球云计算市场掀起了一场深远的地震。VMware长期以来是企业数据中心的核心支柱…...
蓝桥杯篇---按键长按与双击
文章目录 前言1. 新增全局变量和宏定义解释1.1宏定义KEY_EVENT_*DEBOUNCE_TIMEHOLD_TIMEDOUBLE_TIMEMULTI_TIME 1.2全局变量Key_ValKey_OldKey_DownKey_Upsys_tickkey_eventkey_pressedkey_press_startkey_last_releaseclick_cnt 2. 定时器初始化(1ms中断࿰…...
created在vue3 script setup中的写法
在 Vue 2 里,created 是一个生命周期钩子函数,会在实例已经创建完成之后被调用,主要用于在实例初始化之后、数据观测和 event/watcher 事件配置之前执行代码。而在 Vue 3 的 <script setup> 语法糖里,不再有像 Vue 2 那样直…...
基于springboot的房屋租赁系统(008)
摘 要 社会的发展和科学技术的进步,互联网技术越来越受欢迎。网络计算机的生活方式逐渐受到广大人民群众的喜爱,也逐渐进入了每个用户的使用。互联网具有便利性,速度快,效率高,成本低等优点。 因此,构建符…...
Linux上的`i2c-tools`工具集的编译构建和安装
源码复制到Ubuntu系统中并解压 的i2c-tools工具集的源码百度网盘下载链接: https://pan.baidu.com/s/1XNuMuT1auT1dMzYo3LAFmw?pwdi6xe 终端进入源码目录 cd /home/book/mybuild/i2c-tools-4.2执行编译构建命令 运行下面的命令进行编译构建 make CC${CROSS_COM…...
java项目之基于ssm的社区流浪动物救助领养系统
项目简介 社区流浪动物救助领养系统实现了以下功能: 本社区流浪动物救助领养系统分为管理员还有用户两个权限,管理员可以管理用户的基本信息内容,可以管理回访信息以及回访的租赁信息,能够与用户进行相互交流等操作,…...
网络空间安全(34)安全防御体系
前言 安全防御体系是一个多层次、多维度的系统,旨在保护组织或个人的信息资产免受各种网络攻击和威胁。 一、技术层面 网络边界防御 防火墙:部署在网络边界,通过设定规则允许或阻止特定流量的进出,保护内部网络不受外部攻击。入侵…...
《Linux 网络架构:基于 TCP 协议的多人聊天系统搭建详解》
一、系统概述 本系统是一个基于 TCP 协议的多人聊天系统,由一个服务器和多个客户端组成。客户端可以连接到服务器,向服务器发送消息,服务器接收到消息后将其转发给其他客户端,实现多人之间的实时聊天。系统使用 C 语言编写&#x…...
知识蒸馏:让大模型“瘦身”的魔法
知识蒸馏:让大模型“瘦身”的魔法 什么是蒸馏模型?AI界的“知识浓缩术”核心定义传统训练 vs 知识蒸馏关键优势 DeepSeek的蒸馏“三步魔法”骨架提取——搭建“迷你版大脑”知识灌注——模仿教师的“思考过程”微调优化——针对场景“查漏补缺” DeepSee…...
MySQL数据库精研之旅第一期:开启数据管理新旅程
专栏:MySQL数据库成长记 个人主页:手握风云 目录 一、数据库简介 1.1. 数据库的概念 1.2. 数据库和数据结构的关系 1.3. 主流数据库 1.3.1. 关系型数据库 1.3.2. 非关系型数据库 1.4. 关系型数据库的概念 二、MySQL配置 2.1. mysqld服务端程序 …...
Linux复习——基础IO,认识文件描述符、软硬件链接
1.复习C文件接口 1.1 fopen FILE *fopen(const char *path, const char *mode); path:带路径的文件名称(待打开的文件) mode: r:以可读方式打开,不可写,文件不存在,则报错 r&…...
【Java集合夜话】第1篇:拨开迷雾,探寻集合框架的精妙设计
欢迎来到Java集合框架系列的第一篇文章!🌹 本系列文章将以通俗易懂的语言,结合实际开发经验,带您深入理解Java集合框架的设计智慧。🌹 若文章中有任何不准确或需要改进的地方,欢迎大家指出,让我…...