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

【12】数据结构之基于线性表的排序算法

目录标题

  • 插入排序
    • 直接插入排序
    • 折半插入排序
    • 希尔排序
  • 交换排序
    • 冒泡排序
    • 快速排序
  • 归并排序
  • 时间复杂度对比
    • 最好情况
    • 平均情况
    • 最坏情况
  • 空间复杂度对比

插入排序

  • 基本思想:将一个元素插入到一个有序序列中,继而得到一个有序的元素个数加一的新序列.

直接插入排序

  • 基本操作:将第i个元素插入前面i-1个已经排好序的序列中.
  • 示意图:举例序列(21,25,49,25,16,8)

在这里插入图片描述

# 4-1.直接插入排序
class InsertSort:def __init__(self, items):self.items = itemsdef insertSort(self):# 直接插入排序# 从第二个元素开始排序for i in range(1,len(self.items)):# 获取第n个元素temp = self.items[i]j = i-1while j >= 0 and temp < self.items[j]:self.items[j+1] = self.items[j]j -= 1self.items[j+1] = tempif __name__ == '__main__':     # 4-1.直接插入排序print('直接插入排序:')nums = [21, 25, 49, 25, 16, 8]print(f"排序前情况:{nums}")select = InsertSort(nums)select.insertSort()print(f"直接插入排序后情况:{nums}")
  • 最好与最坏的直接插入排序法情况
    • 顺序排序:总的比较次数n-1次;总的移动次数2(n-1)次.
    • 逆序排序:总的比较次数(n-1)(n+2)/2;总的移动次数(n-1)(n+4)/2次.
  • 时间复杂度: O ( n 2 ) \mathcal{O}(n^2) O(n2)

折半插入排序

  • 基本操作:在直接插入排序中,可以在前半部分的有序序列中采用折半查找的方法以提高查找速度.
  • 折半插入排序在次数比较上减少了很多,但是时间复杂度仍然还是: O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 折半插入示意图

在这里插入图片描述

# 4-2.折半插入排序
class BinaryInsertSort:def __init__(self, items):self.items = items  # 初始化待排序数组def binaryInsertSort(self):"""折半插入排序"""for i in range(1, len(self.items)):  # 从第二个元素开始遍历temp = self.items[i]  # 当前待插入元素low = 0high = i - 1  # 已排序区间的右边界# ---------- 折半查找插入位置 ----------while low <= high:mid = (low + high) // 2if self.items[mid] > temp:high = mid - 1  # 插入点在左半区else:low = mid + 1  # 插入点在右半区# 最终插入位置为 high + 1# ---------- 元素后移 & 插入 ----------for j in range(i - 1, high, -1):  # 将 high+1 到 i-1 的元素后移self.items[j + 1] = self.items[j]self.items[high + 1] = temp  # 插入元素到正确位置if __name__ == '__main__':  # 4-2.折半插入排序print('折半插入排序:')nums = [21, 25, 49, 25, 16, 8]print(f"排序前情况:{nums}")select = BinaryInsertSort(nums)select.binaryInsertSort()print(f"折半插入排序后情况:{nums}")print()

希尔排序

  • 基本操作
    • 先取一个小于n的整数d作为第一个增量,把序列的全部元素分为d个组.
    • 在各组内部进行直接插入排序.
    • 再取第二个增量d1(小于d),分为d1个组,在组内进行直接插入排序.
    • 重复,直至增量为1,完成排序.
  • 希尔排序示意图
    在这里插入图片描述
# 4-3.希尔排序
class ShellSort:def __init__(self, items):self.items = itemsdef shellSort(self):if self.items is None or len(self.items) <= 1:returnlength = len(self.items)//4while length > 0:for left in range(len(self.items)):right = left - lengthwhile right >= 0:if self.items[right] > self.items[right + length]:self.items[right], self.items[right+length] = self.items[right+length],self.items[right]right = right - lengthlength //= 2if __name__ == '__main__':# 4-3.希尔排序print('希尔排序:')nums = [46, 55, 13, 42, 94, 17, 5, 70]shell = ShellSort(nums)print(f"排序前情况:{nums}")shell.shellSort()print(f"希尔排序后情况:{nums}")print()
  • 运行情况
    在这里插入图片描述

交换排序

  • 基本思想:根据序列中两个元素关键字的比较结果,判断是否需要交换元素在序列中的位置.

冒泡排序

  • 核心思想:
    • 反复扫描待排序序列,在扫描的过程中顺次比较相邻的两个元素的大小,若为逆序则交换位置.
    • 每一轮排序都将当前未排序的序列中的最大值下沉到最底部,直至得到有序序列.
  • 一轮冒泡排序示意图

在这里插入图片描述

# 5-1.冒泡排序
class BubbleSort:def __init__(self, items):self.items = itemsdef bubbleSort(self):if self.items is None or len(self.items) == 0:returnfor i in range(len(self.items)):for j in range(len(self.items)-1-i):if self.items[j] > self.items[j+1]:self.items[j],self.items[j+1] = self.items[j+1], self.items[j]if __name__ == '__main__':# 5-1.冒泡排序print('冒泡排序:')nums = [21, 25, 49, 25, 16, 8]bubble = BubbleSort(nums)print(f"排序前情况:{nums}")bubble.bubbleSort()print(f"冒泡排序后情况:{nums}")print()  

快速排序

  • 核心思想
    • 是对冒泡排序的一种改进.
    • 算法以某一元素v作为基准,先将待排序序列分为前后两段(前段元素要求均小于v,后段元素要求均大于v),
    • 再分别对前段、后段元素进行快速排序,利用递归调用进行实现,
    • 重复进行,直至得到一个长度为n的有序序列.
  • 一轮快速排序示意图
    在这里插入图片描述
# 5-2.快速排序
class QuickSort:def __init__(self, items):self.items = itemsdef quickSort(self):"""快速排序入口方法"""self._sort(0, len(self.items) - 1)return self.itemsdef _sort(self, left, right):"""递归排序核心逻辑"""if left < right:pivot_index = self._partition(left, right)self._sort(left, pivot_index - 1)  # 递归处理左半部分self._sort(pivot_index + 1, right)  # 递归处理右半部分def _partition(self, left, right):"""划分操作"""pivot = self.items[right]  # 选择最后一个元素为基准值i = left - 1  # 小于基准值的分界指针for j in range(left, right):if self.items[j] <= pivot:i += 1self.items[i], self.items[j] = self.items[j], self.items[i]  # 交换元素# 将基准值放到正确位置self.items[i + 1], self.items[right] = self.items[right], self.items[i + 1]return i + 1  # 返回基准值的最终位置if __name__ == '__main__':# 5-2.快速排序print('快速排序:')nums = [21, 25, 49, 25, 16, 8, 34]quick = QuickSort(nums)print(f"排序前情况:{nums}")quick.quickSort()print(f"快速排序后情况:{nums}")print()
  • 交换排序的运行结果

在这里插入图片描述

归并排序

  • 核心思想
    • 将两个或两个以上有序序列合并成一个新的有序序列.
    • 初始序列含有n个元素,将每个元素看成n个有序子序列.
    • 进行两两归并,得到n/2的有序序列.
    • 递归调用,在之前的基础上,不断地进行两两归并.
    • 直到得到一个长度为n的有序序列.
    • 上述方法也成为2-路归并排序.
  • 2-路归并排序

在这里插入图片描述

# 6.归并排序
class mergeSort:def merge(self, left, right):# 把多个有序序列合并成一个有序序列result = []left_index = 0right_index = 0while left_index < len(left) and right_index < len(right):if left[left_index] <= right[right_index]:result.append(left[left_index])left_index += 1else:result.append(right[right_index])right_index += 1# while循环结束,把剩下的数据添加进去result += right[right_index:]result += left[left_index:]return resultdef mergeSort(self, items):# 归并排序n = len(items)# 递归返回if n == 1:return items# 将数据分为左右两部分mid = n // 2left = items[:mid]right = items[mid:]# 递归拆分left_sort = self.mergeSort(left)right_sort = self.mergeSort(right)return self.merge(left_sort, right_sort)if __name__ == '__main__':print('PyCharm')# 6.归并排序print('归并排序:')nums = [19, 13, 5, 27, 1,26, 31, 16]merge = mergeSort()print(f"排序前情况:{nums}")nums = merge.mergeSort(nums)print(f"归并排序后情况:{nums}")print()
  • 运行结果

在这里插入图片描述

  • 时间复杂度: O ( n log ⁡ 2 n ) \mathcal{O}(n \log_2 n) O(nlog2n)

时间复杂度对比

最好情况

  • 直接插入排序 O ( n ) \mathcal{O}(n) O(n)
  • 折半插入排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 希尔排序 O ( n log ⁡ 2 n ) \mathcal{O}(n \log_2 n) O(nlog2n)
  • 冒泡排序 O ( n ) \mathcal{O}(n) O(n)
  • 快速排序 O ( n log ⁡ 2 n ) \mathcal{O}(n \log_2 n) O(nlog2n)
  • 归并排序 O ( n log ⁡ 2 n ) \mathcal{O}(n \log_2 n) O(nlog2n)

平均情况

  • 直接插入排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 折半插入排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 希尔排序 O ( n 3 / 2 ) \mathcal{O}(n^{3/2}) O(n3/2)
  • 冒泡排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 快速排序 O ( n log ⁡ 2 n ) \mathcal{O}(n \log_2 n) O(nlog2n)
  • 归并排序 O ( n log ⁡ 2 n ) \mathcal{O}(n \log_2 n) O(nlog2n)

最坏情况

  • 直接插入排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 折半插入排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 希尔排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 冒泡排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 快速排序 O ( n 2 ) \mathcal{O}(n^2) O(n2)
  • 归并排序 O ( n log ⁡ 2 n ) \mathcal{O}(n \log_2 n) O(nlog2n)

空间复杂度对比

  • 直接插入排序 O ( 1 ) \mathcal{O}(1) O(1)
  • 折半插入排序 O ( 1 ) \mathcal{O}(1) O(1)
  • 希尔排序 O ( 1 ) \mathcal{O}(1) O(1)
  • 冒泡排序 O ( 1 ) \mathcal{O}(1) O(1)
  • 快速排序 O ( log ⁡ 2 n ) ∼ O ( n ) \mathcal{O}(\log_2 n) \sim \mathcal{O}(n) O(log2n)O(n)
  • 归并排序 O ( n ) \mathcal{O}(n) O(n)

相关文章:

【12】数据结构之基于线性表的排序算法

目录标题 插入排序直接插入排序折半插入排序希尔排序 交换排序冒泡排序快速排序 归并排序时间复杂度对比最好情况平均情况最坏情况 空间复杂度对比 插入排序 基本思想&#xff1a;将一个元素插入到一个有序序列中&#xff0c;继而得到一个有序的元素个数加一的新序列. 直接插…...

解决RecyclerView在调用smoothScrollToPosition后最后一个item底部超出屏幕的问题

要解决RecyclerView在调用smoothScrollToPosition后最后一个item底部超出屏幕的问题&#xff0c;可以使用自定义的LinearSmoothScroller&#xff0c;使其底部对齐屏幕。步骤如下&#xff1a; 创建自定义的SmoothScroller类&#xff1a; 继承LinearSmoothScroller并重写getVerti…...

数字世界的免疫系统:恶意流量检测如何守护网络安全

在2023年全球网络安全威胁报告中,某跨国电商平台每秒拦截的恶意请求峰值达到217万次,这个数字背后是无数黑客精心设计的自动化攻击脚本。恶意流量如同数字世界的埃博拉病毒,正在以指数级速度进化,传统安全防线频频失守。这场没有硝烟的战争中,恶意流量检测技术已成为守护网…...

十分钟机器学习之--------------线性回归

线性回归&#xff08;linear regression&#xff09;是一种基于数学模型的算法&#xff0c;首先假设数据集与标签之间存在线性关系&#xff0c;然后简历线性模型求解参数。在实际生活中&#xff0c;线性回归算法因为其简单容易计算&#xff0c;在统计学经济学等领域都有广泛的应…...

常用 Excel VBA 技巧,简单好学易上手

在日常办公中&#xff0c;我们常常会遇到各种繁琐的数据处理任务&#xff0c;而 Excel VBA&#xff08;Visual Basic for Applications&#xff09;作为一款强大的自动化工具&#xff0c;能够帮助我们轻松应对这些挑战。本文将介绍一些常用且简单好学的 Excel VBA 技巧&#xf…...

第7篇:Linux程序访问控制FPGA端LEDR<五>

Q&#xff1a;如何设计.c程序代码实现FPGA端外设LEDR流水灯&#xff1f; A&#xff1a;在DE1-SoC开发板上实现的流水灯效果&#xff1a;一次只点亮一个红色LED&#xff0c;初始状态为向左移动直至点亮LEDR9&#xff0c;然后改变移动的方向为向右直至点亮LEDR0&#xff0c;以此…...

PyTorch 深度学习实战(35):图生成模型与分子设计

在上一篇文章中&#xff0c;我们探讨了强化学习在机器人控制中的应用。本文将深入介绍图生成模型及其在分子设计领域的应用&#xff0c;这是一个结合深度学习与化学的交叉领域。我们将使用PyTorch Geometric实现基于图神经网络的分子生成模型&#xff0c;并在ZINC250k数据集上进…...

免费送源码:Java+ssm+HTML 三分糖——甜品店网站设计与实现 计算机毕业设计原创定制

录 摘要 1 1 绪论 3 1.1 研究背景 3 1.2 研究意义 3 1.3论文结构与章节安排 3 2系统分析 4 2.1 可行性分析 4 2.2 系统流程分析 4 2.2.1 登录流程 4 2.2.2数据删除流程 5 2.3 系统功能分析 5 2.3.1功能性分析 6 2.3.2 非功能性分析 7 2.4 系统用例分析 7 2.5本章…...

JVM 调试与内存优化实战详解

&#x1f31f; JVM 调试与内存优化实战详解 &#x1f31f; 前言一、JVM 内存模型概览二、常见内存问题与诊断思路三、核心调试工具与命令详解四、实战案例一&#xff1a;频繁 Full GC 深度排查与优化1. &#x1f575;️ 问题现象2. &#x1f52c; 排查流程3. ✅ 优化方案 五、实…...

Linux上通过Docker部署Zabbix6.2监控平台

文章目录 前言Zabbix概述zabbix特性 一、Zabbix架构二、主节点部署容器2.1 部署Docker 三、主节点部署数据库3.1 创建存储卷3.2 查看存储卷3.3 删除存储卷3.4 运行容器MySQL8 四、主节点部署Zabbix4.1 安装zabbix-java-gateway4.2 运行zabbix-server4.3 安装zabbix-web 五、配置…...

Grok3 API 已经免费开放了,附上免费使用 Grok3 API的教程

Grok-3是什么 Grok-3 是 xAI&#xff08;由 Elon Musk 创立的 AI 公司&#xff09;开发的最新大语言模型&#xff08;LLM&#xff09;&#xff0c;属于 Grok 系列模型的第三代&#xff0c;旨在与 OpenAI 的 GPT-4、Anthropic 的 Claude 3 和 Google 的 Gemini 1.5 等顶尖 AI 竞…...

2025年4月9日-华为暑期实习-第三题-300分

📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 03. 矩阵螺旋排序 问题描述 卢小姐是一家艺术展览馆的策展人,她正在为一个数字艺术展览设计一个特殊的展示方案。展览厅的墙面是一个 N N N \times N...

【Web API系列】WebSocketStream API 深度实践:构建高吞吐量实时应用的流式通信方案

前言 在当今的 Web 开发领域&#xff0c;实时通信已成为许多应用的核心需求。无论是即时聊天、实时数据仪表盘&#xff0c;还是在线游戏和金融交易系统&#xff0c;都需要高效的双向数据传输能力。传统的 WebSocket API 为此提供了基础支持&#xff0c;但在处理大规模数据流、…...

WEB攻防-Java安全JNDIRMILDAP五大不安全组件RCE执行不出网不回显

目录 1. RCE执行-5大类函数调用 1.1 Runtime方式 1.2 Groovy执行命令 1.3 脚本引擎代码注入 1.4 ProcessImpl 1.5 ProcessBuilder 2. JNDI注入(RCE)-RMI&LDAP&高版本 2.1 RMI服务中的JNDI注入场景 2.2 LDAP服务中的JNDI注入场景 攻击路径示例&#…...

在android实现Google的web登录

前言 由于业务上的需要,想要在android端实现Google登录。但是android的原生方法受到限制,实现起来比较麻烦。于是想到了一个曲线救国的方法,在android端使用Google的web登录。 实现逻辑 在andorid端拉起外部浏览器,用户登录Google账号,登录成功后,再将登录信息返回到a…...

opencv常用边缘检测算子示例

opencv常用边缘检测算子示例 1. Canny算子2. Sobel算子3. Scharr算子4. Laplacian算子5. 对比 1. Canny算子 从不同视觉对象中提取有用的结构信息并大大减少要处理的数据量的一种技术&#xff0c;检测算法可以分为以下5个步骤&#xff1a; 噪声过滤&#xff08;高斯滤波&…...

安装了VM Tools,仍无法复制拖动-解决方案

今天在安装ubuntu时遇到了困扰许久的问题&#xff0c;安装了VM Tools&#xff0c;仍无法拖动主机文件到虚拟机&#xff0c;主要有两种原因并对应解决办法。 1.相关虚拟机设置选项卡中-客户机隔离-两个功能没有勾选 解决方案&#xff1a;勾选重启虚拟机即可 2.&#xff08;这个…...

一文读懂WPF布局

WPF布局 布局WPF 布局的核心机制常用布局控件详解Grid&#xff08;网格布局&#xff09;StackPanel&#xff08;堆叠布局&#xff09;DockPanel&#xff08;停靠布局&#xff09;WrapPanel&#xff08;自动换行布局&#xff09;Canvas&#xff08;绝对定位布局&#xff09;Unif…...

【Docker基础-网络】--查阅笔记4

目录 Docker 网络网络类型none 网络host 网络bridge 网络自定义网络 容器间通信IP 通信Docker DNS Serverjoined 容器 容器与外部通信容器访问外部外部访问容器 Docker 网络 学习Docker提供的几种原生网络如何创建自定义网络容器间通信&#xff0c;容器于外界交互 Docker 安装…...

FacialExpressionDetection的conda虚拟环境搭建Window

安装conda的URL&#xff1a;Index of /anaconda/archive/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 清华源下载conda版本&#xff0c;哪个最新用哪个&#xff0c;这里下载Anaconda3-5.3.1-Windows-x86_64.exe版本 安装conda虚拟环境 conda create --name py1…...

IPD推进中关键角色与岗位(七)LTDT确保技术开发的实用性与可靠性,满足市场需求

IPD 体系作为一种先进的研发管理模式&#xff0c;其核心在于打破传统职能部门的壁垒&#xff0c;通过跨部门团队的协同合作&#xff0c;实现产品开发的全流程优化。在 IPD 体系的架构中&#xff0c;存在着多个关键团队&#xff0c;它们各司其职又紧密配合&#xff0c;共同推动产…...

c++自学笔记——字符串与指针

字符串与指针 1. 字符串基础 字符串的定义&#xff1a;字符的序列&#xff0c;通常用来表示文本。 字符串字面量&#xff08;String Literal&#xff09;是在程序中直接用双引号括起来的文本序列。字符串字面量的类型是 const char*&#xff0c;即指向字符常量的指针。字符串…...

Jmeter分布式测试启动

代理客户端配置 打开jmeter.properties文件&#xff0c;取消注释并设置端口&#xff08;如server_port1099&#xff09;&#xff0c; 并添加server.rmi.ssl.disabletrue禁用SSL加密。 &#xff08;Linux系统&#xff09;修改jmeter-server文件中的RMI_HOST_DEF为代理机实际IP。…...

.DS_Store文件泄露、.git目录泄露、.svn目录泄露漏洞利用工具

&#x1f409;工具介绍 一款图形化的 .DS_Store文件泄露、.git目录泄露、.svn目录泄露漏洞利用工具。 &#x1f3af;使用 本工具使用Python3 PyQt5开发&#xff0c;在开始使用前&#xff0c;请确保已经安装了相关模块&#xff1a; pip3 install -r requirements.txt -i ht…...

Coze+大模型智能体环境搭建

1 前言 Coze作为字节跳动推出的新一代AI Bot开发平台&#xff0c;为开发者提供了快速构建、部署智能对话代理的一站式解决方案。Coze平台通过提供可视化工作流编排、知识库集成、插件扩展等核心功能&#xff0c;结合一些大模型&#xff0c;例如豆包、deepseek、通义千问等大模型…...

计算机视觉与深度学习 | 视觉SLAM学习思路总结与视觉SLAM发展历程(1986年至2025年)

视觉SLAM(Simultaneous Localization and Mapping,同时定位与建图)是计算机视觉和机器人领域的重要研究方向,涉及数学、几何、优化、传感器融合等多学科知识。以下是学习视觉SLAM的系统化思路总结,适合从入门到进阶的学习路径:视觉SLAM学习思路总结 一、基础准备 数学基…...

Ansible(8)——循环与条件任务

目录 一、循环迭代任务&#xff1a; 1、简单循环&#xff1a; 2、循环字典列表&#xff1a; 3、Ansible 2.5 之前的循环关键字&#xff1a; 4、在循环中使用 register 变量&#xff1a; 二、条件任务&#xff1a; 1、使用条件句的常见场景&#xff1a; 2、条件任务语法…...

搭建Trae+Vue3的AI开发环境

从2024年2025年&#xff0c;不断的有各种AI工具会在自媒体中火起来&#xff0c;号称各种效率王炸&#xff0c;而在AI是否会替代打工人的话题中&#xff0c;程序员又首当其冲。 作为一个后端开发&#xff0c;这篇文章基于Trae工具&#xff0c;来创建和运行一个简单的Vue前端应用…...

【免费公测】可遇AI直播/无人直播/矩阵直播/AI场控

前言 经过了一个多月的内测打磨&#xff0c;实现了非常稳定的无人直播效果&#xff0c;AI直播语音及其真实&#xff0c;软件交互方便&#xff0c;可以快速的构建AI直播间。 免费公测&#xff0c;内置无限激活卡密一张&#xff0c;打开即用。 亮点 高仿真语音模型&#xff0c…...

大数据Hadoop(MapReduce)

MapReduce概述 MapReduce定义 MapReduce是一个分布式运算程序的编程框架&#xff0c;是用户开发“基于Hadoop的数据分析应用”的核心框架。 MapReduce核心功能是将用户编写的业务逻辑代码和自带默认组件整合成一个完整的分布式运算程序&#xff0c;并发运行在一个Hadoop集群上…...

使用apache-jmeter时,控制台打不开应用的解决方法

运行jmeter.bat的时候&#xff0c;提示&#xff1a; findstr 不是内部或外部命令&#xff0c;也不是可运行的程序 或批处理文件。 Not able to find Java executable or version. Please check your Java installation. errorlevel2这个错误信息表明系统无法识别 findstr 命令…...

leetcode 74. 搜索二维矩阵

class Solution {public boolean searchMatrix(int[][] matrix, int target) {int m matrix.length;int n matrix[0].length;int l 0;int r n * m - 1; // 记得减一while (l < r) {int mid (l r) / 2;if(matrix[mid / n][mid % n] > target) {r mid - 1;} else if…...

函数式编程在 Java:Function、BiFunction、UnaryOperator 你真的会用?

大家好&#xff0c;我是你们的Java技术博主&#xff01;今天我们要深入探讨Java函数式编程中的几个核心接口&#xff1a;Function、BiFunction和UnaryOperator。很多同学虽然知道它们的存在&#xff0c;但真正用起来却总是不得要领。这篇文章将带你彻底掌握它们&#xff01;&am…...

SpringMVC基础一(SpringMVC运行原理)

先了解MVC&#xff0c;在JavaWeb基础五中。 回忆servlet&#xff0c;在javaweb基础二中。 创建一个web项目&#xff1a; 1、新建maven项目&#xff0c;导入依赖。&#xff08;junit、springmvc、spring-webmvc、servlet-api、jsp-api、jstl&#xff09; <groupId>org…...

libva之ffavdemo分析

ffavdemo 代码库实现了一个基于FFmpeg和VAAPI的硬件加速视频解码与渲染框架&#xff0c;主要用于演示视频解码与渲染的完整硬件加速流程。支持多种渲染后端&#xff08;X11、DRM、EGL&#xff09;&#xff0c;适应不同显示环境。包含视频处理过滤器&#xff0c;可进行格式转换和…...

从零开始写android 的智能指针

Android中定义了两种智能指针类型&#xff0c;一种是强指针sp&#xff08;strong pointer&#xff09;&#xff0c;源码中的位置在system/core/include/utils/StrongPointer.h。另外一种是弱指针&#xff08;weak pointer&#xff09;。其实称之为强引用和弱引用更合适一些。强…...

Spark-SQL 之 Window

window 函数实例 select concat(substr(p_dt,1,4),substr(p_dt,6,2)...

Python设计模式-单例模式

一、单例模式核心思想 单例模式&#xff08;Singleton Pattern&#xff09;是一种创建型设计模式&#xff0c;它确保一个类只有一个实例&#xff0c;并提供一个全局访问点。该模式主要解决以下问题&#xff1a; 资源控制&#xff08;如数据库连接池&#xff09;配置信息全局一…...

富文本编辑器的内容导出html,并保留图片

富文本编辑器的上传的图片默认转为base64&#xff0c;但是如果需要保存到数据库&#xff0c;base64的数据就太大了&#xff0c;所以一般都会长传到文件服务器&#xff0c;然会返回图片url。 但是当我们需要把富文本编辑器的内容导出为html时&#xff0c;因为图片时url,当浏览器…...

jQueryHTML与插件

1.jQuery 事件机制 1.1 注册事件 bind()、on()方法向被选元素添加一个或多个事件处理程序&#xff0c;以及当事件发生时运行的函数 $("p").on({"click": function () {alert("点击了")},"mouseenter": function () {…...

KTH5772 系列游戏手柄摇杆专用3D 霍尔位置传感器

产品概述 KTH5772是一款专为游戏手柄上的摇杆应用而设计的3D霍尔磁感应芯片&#xff0c;主要面向对线性度、回报率、灵敏度、功耗要求严格的摇杆应用。KTH5772基于3D霍尔技术&#xff0c;内部分别集成了X轴、Y轴和Z轴三个独立的霍尔元件&#xff0c;能够通过测量和处理磁通密度…...

C++进阶——C++11_右值引用和移动语义_可变参数模板_类的新功能

目录 1、右值引用和移动语义 1.1 左值和右值 1.2 左值引用和右值引用 1.3 引用延长生命周期 1.4 左值和右值的参数匹配 1.5 右值引用和移动语义的使用场景 1.5.1 左值引用主要使用场景 1.5.2 移动构造和移动赋值 1.5.3 右值引用和移动语义解决传值返回问题 1.5.4 右值…...

(五)深入了解AVFoundation-播放:多音轨、字幕、倍速播放与横竖屏切换

引言 在之前的博客中&#xff0c;我们已经实现了一个相对完整的播放器&#xff0c;具备了基本功能&#xff0c;如播放、暂停、播放进度显示和拖拽快进等。这为我们提供了一个坚实的基础。接下来&#xff0c;我们将进一步扩展播放器的功能&#xff0c;使其更具灵活性和实用性&a…...

matplotlib.pyplot常见图形及组合基础用法文档

matplotlib.pyplot 常见图形及组合基础用法文档 一、引言 matplotlib.pyplot 是 Python 中用于数据可视化的强大库&#xff0c;提供了丰富的绘图函数&#xff0c;可绘制折线图、散点图、柱状图等多种类型的图形。同时&#xff0c;还能将不同类型的图形组合在一起&#xff0c;…...

mysql的基础语句和外键查询及其语句

思路&#xff1a;双指针思路可以吗&#xff0c;我就直接找G,如果后一个是1就cnt&#xff0c;如果不是数字&#xff0c;用一个指针i指向G&#xff0c;另一个指针j移动&#xff0c;当不是G时停止&#xff0c;统计G的个数&#xff0c;如果是奇数个同时G的下一个是1&#xff0c;cnt…...

如何使用 DeepSeek 帮助自己的工作?

1. 信息检索 信息检索是获取特定信息的过程&#xff0c;尤其是在大量数据或文本中查找相关内容。这个过程应用广泛&#xff0c;从网页搜索引擎到数据库查询&#xff0c;再到企业内部信息系统。在使用 DeepSeek 或其它类似工具进行信息检索时&#xff0c;可以考虑以下几个重要方…...

为 Doub 打造吸引 CMO 的 SEO 报告

在数字营销中&#xff0c;SEO 报告不仅是展示工作成果的工具&#xff0c;更是向高层管理者&#xff08;如 CMO&#xff09;证明 SEO 价值的关键。对于 Doub 这样一家提供精密模切解决方案的网站&#xff08;基于 WordPress 和 WooCommerce&#xff09;&#xff0c;撰写一份吸引…...

数据可视化 —— 折线图应用(大全)

一、导入需要的库 # Matplotlib 是 Python 最常用的绘图库&#xff0c;pyplot 提供了类似 MATLAB 的绘图接口 import matplotlib.pyplot as plt import numpy as np import pandas as pd 二、常用的库函数 plt.plot(x轴,y轴)&#xff1a;plot()是画折线图的函数。 plt.xlabe…...

配置mac mini M4 的一些软件

最近更换了 mac mini M4 &#xff0c;想要重新下载配置软件 &#xff0c;记录一下。 Homebrew是什么&#xff1f; homebrew是一款Mac OS平台下的软件包管理工具&#xff0c;拥有安装、卸载、更新、查看、搜索等功能。通过简单的指令可以实现包管理&#xff0c;而不用关心各种…...

八邻域轮廓跟踪算法_传感器技术

在科学技术日新月异的今天&#xff0c;人们对机器设备的智能性、自主性要求也越来越高&#xff0c;希望其完全替代人的角色&#xff0c;把人们从繁重、危险的工作任务中解脱出来&#xff0c;而能否像人一样具有感知周围环境的能力已成为设备实现智能化自主化的关键。 广义的“…...