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

[c语言日寄]时间复杂度

在这里插入图片描述

【作者主页】siy2333
【专栏介绍】⌈c语言日寄⌋:这是一个专注于C语言刷题的专栏,精选题目,搭配详细题解、拓展算法。从基础语法到复杂算法,题目涉及的知识点全面覆盖,助力你系统提升。无论你是初学者,还是进阶开发者,这里都能满足你的需求!
【食用方法】1.根据题目自行尝试 2.查看基础思路完善题解 3.学习拓展算法
【Gitee链接】资源保存在我的Gitee仓库:https://gitee.com/siy2333/study


文章目录

  • 前言
  • 题目引入
  • 知识点分析
    • 时间复杂度的定义
    • 常见的时间复杂度
    • 时间复杂度的计算方法
    • 时间复杂度的优化策略
  • 注意事项
    • 时间复杂度与实际运行时间
    • 时间复杂度的上界和下界
    • 时间复杂度与空间复杂度的权衡
    • 时间复杂度的计算精度
  • 拓展应用
    • 时间复杂度在算法竞赛中的应用
    • 时间复杂度在实际项目中的应用
    • 时间复杂度在嵌入式系统中的应用
  • 总结


前言

在C语言的编程实践中,时间复杂度是一个至关重要的概念。它不仅反馈了程序的运行效率,还直接决定了代码在处理大规模数据时的可行性。今天,我们就通过一个简单的程序来深入探讨时间复杂度的计算方法、分析技巧以及优化策略,帮助大家更好地理解和应用这一知识点。


题目引入

让我们先来看一个简单的C语言程序,这个程序的功能是计算一个整数数组中所有元素的和:

#include <stdio.h>int main() {int arr[] = {1, 2, 3, 4, 5};int sum = 0;for (int i = 0; i < 5; i++) {sum += arr[i];}printf("Sum = %d\n", sum);return 0;
}

这个程序的逻辑非常简单,它通过一个循环遍历数组中的每个元素,并将它们累加到变量sum中。那么,这个程序的时间复杂度是多少呢?答案是O(n),其中n是数组的长度。这是因为程序中的循环会执行n次,每次循环的操作都是常数时间的。

这个简单的例子展示了时间复杂度的基本概念:它衡量的是程序运行时间与输入规模之间的关系。在实际编程中,我们经常会遇到更复杂的程序,它们的时间复杂度可能更高,也可能更低。理解时间复杂度的计算方法和分析技巧,对于优化代码性能至关重要。

知识点分析

时间复杂度的定义

时间复杂度是衡量算法运行时间与输入规模之间关系的一个指标。它通常用大O符号表示,例如O(1)、O(n)、O(n²)等。大O符号表示的是算法运行时间的上界,即在最坏情况下,算法的运行时间不会超过这个上界。

对于一个简单的循环结构,时间复杂度通常是O(n),其中n是循环的次数。例如,上面的程序中,循环的次数等于数组的长度,因此时间复杂度是O(n)。如果循环嵌套了另一个循环,那么时间复杂度就会变成O(n²),因为每个循环都会执行n次,总共的执行次数就是n×n。

除了循环结构,时间复杂度还与算法的逻辑有关。例如,一个递归算法的时间复杂度可能更高,因为它会重复调用自身,导致执行次数呈指数级增长。而一些高效的算法,如二分查找,其时间复杂度是O(log n),因为每次查找都会将搜索范围缩小一半,大大减少了执行次数。

常见的时间复杂度

在C语言编程中,我们经常会遇到以下几种常见的时间复杂度:

  • O(1):常数时间复杂度。表示算法的运行时间与输入规模无关,无论输入规模多大,运行时间都是常数级别的。例如,访问数组的某个元素、赋值操作等,都是常数时间的操作。
  • O(n):线性时间复杂度。表示算法的运行时间与输入规模成正比。例如,遍历一个数组、线性查找等,都是线性时间的操作。
  • O(n²):平方时间复杂度。表示算法的运行时间与输入规模的平方成正比。例如,嵌套循环、冒泡排序等,都是平方时间的操作。
  • O(log n):对数时间复杂度。表示算法的运行时间与输入规模的对数成正比。例如,二分查找、快速幂等,都是对数时间的操作。
  • O(n log n):线性对数时间复杂度。表示算法的运行时间与输入规模的对数成正比。例如,快速排序、归并排序等,都是线性对数时间的操作。

时间复杂度的计算方法

计算时间复杂度的方法主要是分析程序中的循环结构和递归调用。对于循环结构,我们需要确定循环的次数,以及每次循环的操作时间。对于递归调用,我们需要分析递归的深度和每次递归的操作时间。

例如,对于一个嵌套循环的程序:

int main() {int n = 10;for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {printf("Hello, World!\n");}}return 0;
}

这个程序中,外层循环执行n次,内层循环也执行n次,因此总的执行次数是n×n,时间复杂度是O(n²)。

对于一个递归程序:

int factorial(int n) {if (n == 0) {return 1;} else {return n * factorial(n - 1);}
}

这个程序中,递归的深度是n,每次递归的操作时间是常数级别的,因此时间复杂度是O(n)。

时间复杂度的优化策略

在实际编程中,我们可以通过以下几种方法来优化时间复杂度:

  • 减少循环次数:通过优化算法逻辑,减少不必要的循环次数。例如,使用二分查找代替线性查找,可以将时间复杂度从O(n)降低到O(log n)。
  • 使用高效的算法:选择更高效的算法来解决问题。例如,使用快速排序代替冒泡排序,可以将时间复杂度从O(n²)降低到O(n log n)。
  • 避免重复计算:通过缓存或记忆化技术,避免重复计算相同的结果。例如,在递归计算斐波那契数列时,使用记忆化技术可以将时间复杂度从O(2^n)降低到O(n)。
  • 使用数据结构:选择合适的数据结构来存储和操作数据。例如,使用哈希表可以实现O(1)时间的查找和插入操作,大大提高了程序的效率。

注意事项

时间复杂度与实际运行时间

虽然时间复杂度是一个重要的指标,但它并不能完全反映程序的实际运行时间。实际运行时间还受到硬件环境、编译器优化、输入数据等因素的影响。因此,在实际编程中,我们不能仅仅依赖时间复杂度来评估程序的性能,还需要结合实际运行情况进行测试和优化。

时间复杂度的上界和下界

时间复杂度通常表示的是算法运行时间的上界,即在最坏情况下,算法的运行时间不会超过这个上界。然而,在实际运行中,算法的运行时间可能低于这个上界。例如,一个线性查找算法的时间复杂度是O(n),但在最好的情况下,它只需要一次比较就可以找到目标元素,运行时间是O(1)。因此,我们还需要考虑算法的下界,即在最好情况下,算法的运行时间是多少。

时间复杂度与空间复杂度的权衡

在优化时间复杂度时,我们可能会增加程序的空间复杂度。例如,使用哈希表可以实现O(1)时间的查找和插入操作,但需要额外的空间来存储哈希表。因此,在实际编程中,我们需要根据具体需求,权衡时间复杂度和空间复杂度,选择最适合的优化策略。

时间复杂度的计算精度

在计算时间复杂度时,我们通常会忽略常数项和低阶项,只关注最高阶项。这是因为当输入规模较大时,常数项和低阶项的影响可以忽略不计。然而,在某些情况下,常数项和低阶项也可能对程序的性能产生影响。例如,一个时间复杂度为O(n²)的算法可能比一个时间复杂度为O(n log n)的算法更快,如果前者的常数项较小,而后者的常数项较大。因此,在实际编程中,我们不能仅仅依赖时间复杂度的计算结果,还需要结合实际运行情况进行测试和优化。

拓展应用

时间复杂度在算法竞赛中的应用

在算法竞赛中,时间复杂度是一个至关重要的因素。竞赛题目通常会给出输入规模的范围,参赛者需要根据这个范围选择合适的算法,以确保程序在规定的时间内完成运行。例如,如果输入规模是10^5,那么一个时间复杂度为O(n²)的算法可能会超时,而一个时间复杂度为O(n log n)的算法则可以顺利通过。

为了提高程序的效率,参赛者通常会使用一些高效的算法和数据结构,如快速排序、二分查找、哈希表、并查集等。同时,他们还会通过优化算法逻辑、减少循环次数、避免重复计算等方法来降低时间复杂度。在实际竞赛中,时间复杂度的优化往往可以决定参赛者的胜负。

时间复杂度在实际项目中的应用

在实际项目中,时间复杂度同样是一个重要的考虑因素。例如,在一个大数据处理项目中,程序需要处理海量的数据,时间复杂度的高低会直接影响程序的运行效率和响应时间。如果程序的时间复杂度过高,可能会导致程序运行缓慢,甚至无法完成任务。

为了提高程序的效率,开发人员通常会使用一些高效的数据处理算法和框架,如MapReduce、Spark等。同时,他们还会通过优化代码逻辑、减少不必要的计算、使用缓存技术等方法来降低时间复杂度。在实际项目中,时间复杂度的优化不仅可以提高程序的性能,还可以降低硬件成本和运维成本。

时间复杂度在嵌入式系统中的应用

在嵌入式系统中,时间复杂度也是一个重要的考虑因素。嵌入式系统的硬件资源通常比较有限,程序需要在有限的资源下完成任务。如果程序的时间复杂度过高,可能会导致程序运行缓慢,甚至无法完成任务。

为了提高程序的效率,开发人员通常会使用一些高效的算法和数据结构,如二分查找、快速排序等。同时,他们还会通过优化代码逻辑、减少不必要的计算、使用硬件加速等方法来降低时间复杂度。在实际嵌入式系统中,时间复杂度的优化不仅可以提高程序的性能,还可以延长设备的使用寿命。

总结

时间复杂度是C语言编程中一个非常重要的概念,它衡量的是程序运行时间与输入规模之间的关系。通过计算和分析时间复杂度,我们可以优化代码性能,提高程序的运行效率。在实际编程中,我们需要注意时间复杂度与实际运行时间的关系、时间复杂度的上界和下界、时间复杂度与空间复杂度的权衡以及时间复杂度的计算精度等问题。

关注窝,每个月至少更新11篇优质c语言题目详解~

[专栏链接QwQ] :⌈c语言日寄⌋CSDN
[关注博主ava]:siy2333
感谢观看~ 我们下次再见!!

相关文章:

[c语言日寄]时间复杂度

【作者主页】siy2333 【专栏介绍】⌈c语言日寄⌋&#xff1a;这是一个专注于C语言刷题的专栏&#xff0c;精选题目&#xff0c;搭配详细题解、拓展算法。从基础语法到复杂算法&#xff0c;题目涉及的知识点全面覆盖&#xff0c;助力你系统提升。无论你是初学者&#xff0c;还是…...

快速幂(蓝桥杯)

1. 递归实现 递归方法通过将问题分解为更小的子问题来实现。具体步骤如下&#xff1a; 如果指数 b 为 0&#xff0c;返回 1。 如果 b 是偶数&#xff0c;则递归计算 (a^2)b/2。 如果 b 是奇数&#xff0c;则递归计算 a⋅(a^2)(b−1)/2。 伪代码&#xff1a; function fas…...

[Python基础速成]2-模块与包与OOP

上篇➡️[Python基础速成]1-Python规范与核心语法 目录 Python模块创建模块与导入属性__name__dir()函数标准模块 Python包类类的专有方法 对象继承多态 Python模块 Python 中的模块&#xff08;Module&#xff09;是一个包含 Python 定义和语句的文件&#xff0c;文件名就是模…...

Spring AOP 学习笔记 之 常用注解

0 引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId><version>3.4.2</version></dependency> 要在springboot中启用AOP&#xff0c;需要引入spring-boot-…...

JVM——运行时数据区

目录 Class装载到JVM的过程 装载&#xff08;load&#xff09;——查找和导入class文件 正文------------------- Run-time Data Areas 运行时数据区 Method Area 方法区 Heap 堆 Java Virtual Machine Stacks&#xff08;Java虚拟机栈&#xff09; The PC Register 程…...

Conda 入门指令教程

Conda 入门指令教程 Conda 是一个强大的包和环境管理工具&#xff0c;广泛应用于数据科学和机器学习项目中。本文将介绍 Conda 的常用指令&#xff0c;帮助你快速上手。 1. Conda 基础操作 查看 Conda 版本 conda --version显示当前安装的 Conda 版本。 更新 Conda conda…...

基于STM32、HAL库的MAX14830总线转UART驱动程序设计

一、简介: MAX14830是一款四通道UART扩展器,通过SPI或I2C接口与微控制器通信。主要特性包括: 4个独立的全双工UART通道 可编程波特率(最高达12Mbps) 每个通道有128字节的发送和接收FIFO 支持硬件和软件流控制 可配置的GPIO引脚 工作电压:1.7V至5.5V 低功耗模式 二、硬件…...

x-cmd install | jellex - 用 Python 语法在终端里玩转 JSON 数据!

目录 核心功能与特点安装优势亮点适用场景 还在为命令行下处理 JSON 数据烦恼吗&#xff1f;jellex 来了&#xff01;它是一款基于终端的交互式 JSON 和 JSON Lines 数据处理工具&#xff0c;让你用熟悉的 Python 语法&#xff0c;轻松过滤、转换和探索 JSON 数据。 核心功能与…...

2025天梯赛 L2专项训练

L2-049 鱼与熊掌 - 团体程序设计天梯赛-练习集 思路就是模拟&#xff0c;正常写就完事 #include<bits/stdc.h> using namespace std; int main() {int a, b;cin >> a >> b;vector<vector<int>>arr(a, vector<int>(0));for (int i 0; i &…...

214、【数组】下一个排列(Python)

题目描述 原题链接&#xff1a;31. 下一个排列 思路 从后往前&#xff0c;找到第一个小于右侧集合的数&#xff0c;从右侧集合中找到一个比该数大的最小的数替换上去。 然后&#xff0c;将右侧集合从小到排列&#xff0c;就为当前排列中&#xff0c;下一个排列的数。 代码实…...

Why does Java‘s hashCode() in String use 31 as a multiplier?

HashCode 为什么使用 31 作为乘数&#xff1f; 1. 固定乘积 31 在这用到了2. 来自 stackoverflow 的回答3. Hash 值碰撞概率统计3.1 读取单词字典表3.2 Hash 计算函数3.3 Hash 碰撞概率计算封装碰撞统计信息的类3.4 针对一组乘数&#xff0c;分别计算碰撞率3.5 碰撞结果可视化3…...

如何将一个8s的接口优化到500ms以下

最近换了个工作&#xff0c;刚入职就接了个活--优化公司自营app的接口性能&#xff0c;提升用户体验。 刚开始还以为是1s优化到500ms这种&#xff0c;或者500ms优化到200ms的接口&#xff0c;感觉还挺有挑战的。下好app体验了一下。好家伙&#xff0c;那个慢已经超过了我的忍耐…...

如何保证本地缓存和redis的一致性

1. Cache Aside Pattern&#xff08;旁路缓存模式&#xff09;​​ ​核心思想​&#xff1a;应用代码直接管理缓存与数据的同步&#xff0c;分为读写两个流程&#xff1a; ​读取数据​&#xff1a; 先查本地缓存&#xff08;如 Guava Cache&#xff09;。若本地未命中&…...

30天学Java第十天——反射机制

反射机制 反射机制是 Java 语言中的一个重要特性&#xff0c;它允许程序在运行时动态地获取类的信息&#xff08;如类的属性、方法和构造器等&#xff09;&#xff0c;并且可以操作这些信息。 反射机制在某些情况下非常有用&#xff0c;例如开发框架、库&#xff0c;或者需要进…...

Nodejs Express框架

参考&#xff1a;Node.js Express 框架 | 菜鸟教程 第一个 Express 框架实例 接下来我们使用 Express 框架来输出 "Hello World"。 以下实例中我们引入了 express 模块&#xff0c;并在客户端发起请求后&#xff0c;响应 "Hello World" 字符串。 创建 e…...

视频设备轨迹回放平台EasyCVR打造货运汽车安全互联网视频监控与管理方案

一、背景介绍 随着互联网发展&#xff0c;货运中介平台大量涌现&#xff0c;行业纠纷也随之增多。尽管当前平台APP具备录音和定位功能&#xff0c;但货物交易流程的全方位监控仍无法实现。主流跟踪定位服务大部分聚焦货物轨迹与车辆定位&#xff0c;尚未实现货物全程可视化监控…...

玩转Docker | 使用Docker部署Docmost文档管理系统

玩转Docker | 使用Docker部署Docmost文档管理系统 前言一、Docmost介绍Docmost 简介Docmost 特点二、系统要求环境要求环境检查Docker版本检查检查操作系统版本三、部署Docmost服务下载镜像编辑部署文件创建容器检查容器状态检查服务端口安全设置四、访问Docmost服务访问Docmos…...

docker方式项目部署(安装容器组件+配置文件导入Nacos+dockerCompose文件创建管理多个容器+私有镜像仓库Harbor)

基于docker的部署 服务器主机ip 192.168.6.131 安装组件 安装redis docker pull redis:7.0.10#在宿主机上/var/lib/docker/volumes/redis-config/_data/目录下创建一个redis配置文件 vim redis.conf#内容如下 appendonly yes #开启持久化 port 6379 #requirepass 1234 #密码…...

基于OpenCV与PyTorch的智能相册分类器全栈实现教程

引言&#xff1a;为什么需要智能相册分类器&#xff1f; 在数字影像爆炸的时代&#xff0c;每个人的相册都存储着数千张未整理的照片。手动分类不仅耗时&#xff0c;还容易遗漏重要瞬间。本文将手把手教你构建一个基于深度学习的智能相册分类系统&#xff0c;实现&#xff1a;…...

C++中string库常用函数超详细解析与深度实践

目录 一、引言 二、基础准备&#xff1a;头文件与命名空间 三、string对象的创建与初始化(基础&#xff09; 3.1 直接初始化 3.2 动态初始化&#xff08;空字符串&#xff09; 3.3 基于字符数组初始化 3.4 重复字符初始化 四、核心函数详解 4.1 字符串长度相关 4.1.1 …...

数据结构(3)

实验步骤&#xff1a; 任务&#xff1a;要求使用自定义函数来实现 输入一段文本&#xff0c;统计每个字符出现的次数&#xff0c;按照字符出现次数从多到少&#xff0c;依次输出&#xff0c;格式如下&#xff1a; 字符1-个数 字符2-个数 ...... 解题思路&#xff1a; 构建结构体…...

【C++教程】使用printf语句实现进制转换

在C语言中&#xff0c;printf 函数可以直接实现部分进制转换功能&#xff0c;通过格式说明符&#xff08;format specifier&#xff09;快速输出不同进制的数值。以下是详细使用方法及示例代码&#xff1a; 一、printf 原生支持的进制转换 1. 十进制、八进制、十六进制转换 #…...

el-dialog设置append-to不生效;el-dialog设置挂载层级

文章目录 一、场景二、注意点1. append-to-body何时为true2.设置层级&#xff0c;遮罩层大小不生效3.相关代码 三、ElMessageBox遮罩层 效果&#xff1a; 一、场景 正常情况下&#xff0c;el-dialog的弹框是挂载在body下的&#xff0c;导致我们会有修改样式或者修改弹框的遮罩…...

互联网软件开发自动化平台 的多维度对比分析,涵盖架构、功能、适用场景、成本等关键指标

以下是关于 互联网软件开发自动化平台 的详细解析&#xff0c;涵盖其核心概念、主流平台的功能、架构设计、适用场景及对比分析&#xff1a; 一、自动化平台的定义与核心目标 自动化平台&#xff08;如CI/CD平台&#xff09;是用于 持续集成&#xff08;CI&#xff09; 和 持续…...

UE5 制作方块边缘渐变边框效果

该效果基于之前做的&#xff08;https://blog.csdn.net/grayrail/article/details/144546427&#xff09;进行修改得到&#xff0c;思路也很简单&#xff1a; 1.打开实时预览 1.为了制作时每个细节调整方便&#xff0c;勾选Live Update中的三个选项&#xff0c;开启实时预览。…...

深入探究 GRU 模型:梯度爆炸问题剖析

在深度学习领域&#xff0c;循环神经网络&#xff08;RNN&#xff09;及其变体在处理序列数据时展现出了强大的威力。其中&#xff0c;门控循环单元&#xff08;GRU&#xff09;作为 RNN 的一种进阶架构&#xff0c;备受关注。今天&#xff0c;咱们就来深入聊聊 GRU 模型&#…...

生成对抗网络(GAN)原理详解

生成对抗网络&#xff08;GAN&#xff09;原理详解 1. 背景 生成对抗网络&#xff08;Generative Adversarial Network, GAN&#xff09;由 Ian Goodfellow 等人于 2014 年提出&#xff0c;是一种通过对抗训练生成高质量数据的框架。其核心思想是让两个神经网络&#xff08;生…...

CFD中的动量方程非守恒形式详解

在计算流体力学&#xff08;CFD&#xff09;中&#xff0c;动量方程可以写成守恒形式和非守恒形式&#xff0c;两者在数学上等价&#xff0c;但推导方式和应用场景不同。以下是对非守恒形式的详细解释&#xff1a; 1. 动量方程的守恒形式 首先回顾守恒形式的动量方程&#xff…...

AIoT 智变浪潮演讲实录 | 刘浩然:让硬件会思考:边缘大模型网关助力硬件智能革新

4 月 2 日&#xff0c;由火山引擎与英特尔联合主办的 AIoT “智变浪潮”技术沙龙在深圳成功举行&#xff0c;活动聚焦 AI 硬件产业的技术落地与生态协同&#xff0c;吸引了芯片厂商、技术方案商、品牌方及投资机构代表等 700 多位嘉宾参会。 会上&#xff0c;火山引擎边缘智能高…...

4.B-树

一、常见的查找方式 顺序查找 O(N) 二分查找 O(logN)(要求有序和随机访问) 二叉搜索树 O(N) 平衡二叉搜索树(AVL树和红黑树) O(logN) 哈希 O(1) 考虑效率和要求而言,正常选用 平衡二叉搜索树 和 哈希 作为查找方式。 但这两种结构适合用于数据量相对不是很大,能够一次性…...

怎么看英文论文 pdf沉浸式翻译

https://arxiv.org/pdf/2105.09492 Immersive Translate Xournal打开...

计算机三级第一章:信息安全保障概述(以时间节点推进的总结)

淡蓝色为必背内容 第一阶段:电讯技术的发明19世纪30年代:电报电话的发明 1835年:莫尔斯(Morse)发明了电报 1837年:莫尔斯电磁式有线电报问世 1878年:人工电话交换局出现 1886年:马可尼发明了无线电报机 1876年:贝尔(Bell)发明了电话机 1892年,史瑞桥自动交换…...

车载软件架构 ---单个ECU的AUTOSAR开发流程

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 周末洗了一个澡,换了一身衣服,出了门却不知道去哪儿,不知道去找谁,漫无目的走着,大概这就是成年人最深的孤独吧! 旧人不知我近况,新人不知我过…...

【场景应用7】在TPU上使用Flax/JAX对Transformers模型进行语言模型预训练

在本笔记本中,我们将展示如何使用Flax在TPU上预训练一个🤗 Transformers模型。 这里将使用GPT2的因果语言建模目标进行预训练。 正如在这个基准测试中所看到的,使用Flax/JAX在GPU/TPU上的训练通常比使用PyTorch在GPU/TPU上的训练要快得多,而且也可以显著降低成本。 Fla…...

C++运算符重载全面总结

C运算符重载全面总结 运算符重载是C中一项强大的特性&#xff0c;它允许程序员为自定义类型定义运算符的行为。以下是关于C运算符重载的详细总结&#xff1a; 一、基本概念 1. 什么是运算符重载 运算符重载是指为自定义类型&#xff08;类或结构体&#xff09;重新定义或重…...

PTA | 实验室使用排期

目录 题目&#xff1a; 输入格式&#xff1a; 输出格式&#xff1a; 输入样例&#xff1a; 输出样例&#xff1a; 样例解释&#xff1a; 代码&#xff1a; 无注释版&#xff1a; 有注释版&#xff1a; 题目&#xff1a; 受新冠疫情影响&#xff0c;当前大家的活动都…...

3.7 字符串基础

字符串 &#xff08;str&#xff09;&#xff1a;和列表用法基本一致 1.字符串的创建 -str转换(字符串&#xff0c;可用于将其他字符类型转换为字符串) -单引号 双引号 三引号 2.索引 3.字符串的切片 4.字符串的遍历 5.字符串的格式化 6.字符串的运算符 7.字符串的函数 #…...

《 C++ 点滴漫谈: 三十三 》当函数成为参数:解密 C++ 回调函数的全部姿势

一、前言 在现代软件开发中&#xff0c;“解耦” 与 “可扩展性” 已成为衡量一个系统架构优劣的重要标准。而在众多实现解耦机制的技术手段中&#xff0c;“回调函数” 无疑是一种高效且广泛使用的模式。你是否曾经在编写排序算法时&#xff0c;希望允许用户自定义排序规则&a…...

16bit转8bit的常见方法(图像归一化)

文章目录 16-bit转8-bit的常用方法一、数据类型转换&#xff1a;image.astype(np.uint8) —— 若数值 x 超出 0-255 范围&#xff0c;则取模运算。如&#xff1a;x 600 % 256 88二、截断函数&#xff1a;np.clip().astype(np.uint8) —— 若数值 x 超出 0-255 范围&#xff0…...

消息中间件kafka,rabbitMQ

在分布式系统中,消息中间件是实现不同组件之间异步通信的关键技术。Kafka 和 RabbitMQ 是两个非常流行的消息中间件系统,它们各自有着不同的特点和应用场景。下面将分别介绍 Kafka 和 RabbitMQ,并讨论它们在消息队列中的使用。 一、Kafka (Apache Kafka) 主要特点: 高吞吐…...

C语言编译预处理3

条件编译&#xff1a;是对源程序的一部分指定编译条件&#xff0c;满足条件进行编译否则不编译。 形式1 #indef 标识符 程序段1 #else 程序段2 #endif 标识符已经被定义用#ifdef #include <stdio.h>// 可以通过注释或取消注释下面这行来控制是否定义 DEBUG 宏 // …...

数据结构·树

树的特点 最小连通图 无环 有且只有 n − 1 n-1 n−1 条边 树的建立方式 顺序存储 只适用于满n叉树&#xff0c;完全n叉树 1<<n 表示结点 2 n 2^n 2nP4715 【深基16.例1】淘汰赛 void solve() {cin >> n;for (int i 0; i<(1<<n); i) {cin >&g…...

队列的各种操作实现(数据结构C语言多文件编写)

1.先创建queue.h声明文件(Linux命令&#xff1a;touch queue.h)。编写函数声明如下(打开文件 Linux 操作命令&#xff1a;vim queue.h): //头文件 #ifndef __QUEUE_H__ #define __QUEUE_H__ //队列 typedef struct queue{int* arr;int in;int out;int cap;int size; }queue_t;…...

48V/2kW储能电源纯正弦波逆变器详细设计方案-可量产

48V/2kW储能电源纯正弦波逆变器详细设计方案 1.后级驱动电路图 2.前级驱动电路图 3.功率表电路原理图 4.功率板BOM: 5.后级驱动BOM 6.前级驱动BOM...

[redis进阶二]分布式系统之主从复制结构(2)

目录 一 redis的拓扑结构 (1)什么是拓扑 (2)⼀主⼀从结构 (3)⼀主多从结构 (4)树形主从结构 (5)三种拓扑结构的优缺点,以及适用场景 二 redis的复制原理 (1)复制过程 (2)数据同步psync replicationid/replid (复制id)(标注同步的数据来自哪里:数据来源) offset (偏移…...

Playwright多语言生态:跨Python_Java_.NET的统一采集方案

一、问题背景&#xff1a;爬虫多语言割裂的旧时代 在大规模数据采集中&#xff0c;尤其是学术数据库如 Scopus&#xff0c;开发者常遇到两个经典问题&#xff1a; 技术语言割裂&#xff1a;Python开发人员使用Selenium、requests-html等库&#xff1b;Java阵营使用Jsoup或Htm…...

day30 第八章 贪心算法 part04

452. 用最少数量的箭引爆气球 先排序&#xff0c;再算重叠区间 class Solution:def findMinArrowShots(self, points: List[List[int]]) -> int:if len(points)0:return 0points.sort(keylambda x:x[0])result 1for i in range(1, len(points)):if points[i][0] > point…...

java操作redis库,开箱即用

application.yml spring:application:name: demo#Redis相关配置redis:data:# 地址host: localhost# 端口&#xff0c;默认为6379port: 6379# 数据库索引database: 0# 密码password:# 连接超时时间timeout: 10slettuce:pool:# 连接池中的最小空闲连接min-idle: 0# 连接池中的最…...

clickhouse中的窗口函数

窗口函数 边界核心参数 窗口边界通过 ROWS、RANGE 或 GROUPS 模式定义,语法为: ROWS BETWEEN AND 基于 ​物理行位置 定义窗口,与排序键的实际值无关,适用于精确控制窗口行数 – 或 RANGE BETWEEN AND 基于 ​排序键的数值范围 定义窗口,适用于时间序列或连续数值的场景(…...

YZ系列工具之YZ02:字典的多功能应用

我给VBA下的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。我的教程一共九套一部VBA手册&#xff0c;教程分为初级、中级、高级三大部分。是对VBA的系统讲解&#xff0c;从简单的…...