二分#背包#快排#LCS详解

二分#背包#快排#LCS详解

文章目录

  • 二分#背包#快排#LCS详解
    • 1. 二分搜索
    • 2. 01背包问题
    • 3. 快速排序
    • 4. 最长公共子序列

1. 二分搜索

在处理大规模数据集时,查找操作的效率显得尤为重要。二分搜索是一种在有序数组中查找目标值的高效算法,其时间复杂度为O(log n)。

二分搜索通过每次比较目标值与数组中间元素的大小来缩小搜索范围。每次比较后,搜索范围缩小一半,直到找到目标值或搜索范围为空。

二分搜索适用于以下场景:

  1. 快速查找有序数组中的目标值。
  2. 数据库系统中常用二分搜索在B树或B+树索引中查找记录。
  3. 需要在算法中频繁查找数据的场景,如在排序数据中查找特定元素。

力扣 LCR 068. 搜索插入位置
给定一个排序的整数数组 nums 和一个整数目标值 target ,请在数组中找到 target ,并返回其下标。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

请必须使用时间复杂度为 O(log n) 的算法。

示例 1:
输入: nums = [1,3,5,6], target = 5
输出: 2

示例 2:
输入: nums = [1,3,5,6], target = 2
输出: 1

示例 3:
输入: nums = [1,3,5,6], target = 7
输出: 4

示例 4:
输入: nums = [1,3,5,6], target = 0
输出: 0

示例 5:
输入: nums = [1], target = 0
输出: 0

提示:
1 <= nums.length <= 104
-104 <= nums[i] <= 104
nums 为无重复元素的升序排列数组
-104 <= target <= 104

案例代码

class Solution:def searchInsert(self, nums: List[int], target: int) -> int:l,r=0,len(nums)-1while l<=r:mid=(l+r)//2if nums[mid]==target:return midelif nums[mid]>target:r=mid-1else :l=mid+1return l

2. 01背包问题

C/C++详解地址:01背包和完全背包

背包问题是一类经典的优化问题,涉及在给定容量的背包中选择物品以使得背包内物品的总价值最大化。

0/1背包问题通过动态规划解决,使用一个二维数组 dp 来记录每个子问题的解。dp[i][w] 表示前 i 个物品在背包容量为 w 时的最大价值。

背包问题适用于以下场景:

  1. 在有限资源下,如何选择最优方案以获得最大收益。
  2. 在有限资金下选择投资组合以最大化收益。
  3. 在有限预算下选择项目组合以最大化回报。

例题
在这里插入图片描述

动态规划:

dp[i][j] = max(dp[i-1][j], dp[i-1][j-wi] + vi)

Python代码实现

n,v=map(int,input().split())
dp=[[0]*(v+1) for i in range(n+1)] # [[0]*cols for i in range(rows)]for i in range(1,n+1):wi,vi=map(int,input().split())for j in range(0,v+1):if j>=wi:dp[i][j]=max(dp[i-1][j],dp[i-1][j-wi]+vi)else:dp[i][j]=dp[i-1][j]print(dp[n][v])

3. 快速排序

快速排序是一种高效的排序算法,其平均时间复杂度为O(n log n)。快速排序通过分治法将数组分成两部分,递归地排序每部分。

快速排序通过选择一个基准元素(pivot),将数组分为两部分,一部分小于基准元素,另一部分大于基准元素。然后递归地对这两部分进行排序。

快速排序适用于以下场景:

  1. 处理大规模数据集的排序任务。
  2. 大多数编程语言的内置排序函数都采用了快速排序或其变种。
  3. 在数据分析和处理过程中,对数据进行排序以便后续操作。

力扣 4. 排序数组
给你一个整数数组 nums,请你将该数组升序排列。

示例 1:
输入:nums = [5,2,3,1]
输出:[1,2,3,5]

示例 2:
输入:nums = [5,1,1,2,0,0]
输出:[0,0,1,1,2,5]

提示:
1 <= nums.length <= 5 * 104
-5 * 104 <= nums[i] <= 5 * 104

python代码示例

class Solution:def sortArray(self, nums: List[int]) -> List[int]:def partition(arr, low, high):pivot = arr[low]                                        left, right = low, high     while left < right:while left<right and arr[right] >= pivot:          right -= 1arr[left] = arr[right]                             while left<right and arr[left] <= pivot:         left += 1arr[right] = arr[left]                        arr[left] = pivot          return leftdef randomPartition(arr, low, high):pivot_idx = random.randint(low, high)                   arr[low], arr[pivot_idx] = arr[pivot_idx], arr[low]     return partition(arr, low, high)def quickSort(arr, low, high):if low >= high:            return     mid = randomPartition(arr, low, high)   quickSort(arr, low, mid-1)            quickSort(arr, mid+1, high)quickSort(nums, 0, len(nums)-1)             return nums

4. 最长公共子序列

C/C++详解地址:LCS、LIS模型详解

最长公共子序列(LCS)是指在两个序列中,找出长度最长的公共子序列。

LCS通过动态规划解决,使用一个二维数组 dp 来记录每个子问题的解。dp[i][j] 表示 text1[0..i-1]text2[0..j-1] 的LCS长度。

LCS适用于以下场景:

  1. 文本比较:在文本处理和比较中,用于查找两个文本的相似度。
  2. 版本控制:在版本控制系统中,用于计算两个版本之间的差异。
  3. 生物信息学:在基因序列分析中,用于查找DNA序列的相似部分。

python代码示例

def LCS(a, b):n = len(a)m = len(b)dp = [[0] * (m + 1) for _ in range(n + 1)]for i in range(1, n + 1):for j in range(1, m + 1):if a[i - 1] == b[j - 1]:dp[i][j] = dp[i - 1][j - 1] + 1else:dp[i][j] = max(dp[i - 1][j], dp[i][j - 1])return dp[n][m]n,m=map(int,input().split())
a=list(map(int,input().split()))
b=list(map(int,input().split()))result = LCS(a, b)
print(result)

如果对Golang、Mysql、Linux感兴趣的小伙伴,也可以关注我的公众号0.o
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/25422.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

集群与分片:深入理解及应用实践

目录 引言什么是集群&#xff1f; 集群的定义集群的类型 什么是分片&#xff1f; 分片的定义分片的类型 集群与分片的关系集群的应用场景 负载均衡高可用性 分片的应用场景 大数据处理数据库分片 集群与分片的架构设计 系统架构设计数据存储设计 案例分析 Hadoop 集群Elastics…

【python报错】关于 xlrd.biffh.XLRDError: Excel xlsx file; not supported 解决方法【已解决】

【Python报错】关于xlrd.biffh.XLRDError: Excel xlsx file; not supported解决方法【已解决】 在使用Python进行数据分析时&#xff0c;经常需要处理Excel文件。xlrd库是一个流行的用于读取Excel文件的库&#xff0c;但如果你在使用xlrd打开.xlsx文件时遇到了xlrd.biffh.XLRDE…

区块链(Blockchain)调查研究(一)

文章目录 1. 区块链是什么&#xff1f;2. 区块链分类和特点3. 区块链核心关键技术3.1 共识机制3.2 密码学技术3.4 分布式存储3.5 智能合约 4. 区块链未来发展趋势5. 区块链能做什么、不能做什么&#xff1f;5.1 第一部分5.2 第二部分5.3 第三部分&#xff08;结论&#xff09; …

新书推荐:2.3 消息机制

Windows程序的消息机制是指在Windows操作系统下&#xff0c;应用程序与操作系统之间的一种通信方式。通过消息机制&#xff0c;应用程序可以接收来自操作系统的各种事件和请求&#xff0c;以便做出相应的响应和处理。 在Windows程序中&#xff0c;消息机制的实现是基于消息队列…

用 Axios 封装一个双 token 无感刷新

为什么要用双Token无感刷新&#xff0c;它解决了什么问题&#xff1f; 为了保证安全性&#xff0c;后端设置的Token不可能长期有效&#xff0c;过了一段时间Token就会失效。而发送网络请求的过程又是需要携带Token的&#xff0c;一旦Token失效&#xff0c;用户就要重新登陆&…

前台怎么调用Oracle proc过程

前台调用Oracle PROC过程通常涉及几种不同的方法&#xff0c;具体取决于你的前台应用程序所使用的技术和框架。以下是一些常见的方法&#xff0c;以及如何在前台调用Oracle PROC过程的详细步骤&#xff1a; 1. 使用PL/SQL Developer或其他SQL工具 直接调用&#xff1a;在PL/S…

将操作与数据分离 - 面向数据编程 v1.1

面向数据编程 (DOP) 非常注重数据&#xff0c;此次讨论的原则涉及实现大多数域逻辑的方法&#xff0c;它建议将操作与数据分开。 1.示例场景 此次讨论面向数据编程 v1.1的将操作与数据分离原则的具体示例是以销售平台作为示例&#xff0c;该平台销售书籍、家具和电子设备&…

欢乐打地鼠小游戏html源码

这是一款简单的js欢乐打地鼠游戏&#xff0c;挺好玩的&#xff0c;老鼠出来用鼠标点击锤它&#xff0c;击中老鼠获得一积分。 欢乐打地鼠小游戏html源码

kopf,一个实用的 Python 库!

更多Python学习内容&#xff1a;ipengtao.com 大家好&#xff0c;今天为大家分享一个实用的 Python 库 - kopf。 Github地址&#xff1a;https://github.com/nolar/kopf 在 Kubernetes 中&#xff0c;Operator 是一种用于扩展 Kubernetes 功能的强大工具。Operator 可以自动化应…

MySQL之查询性能优化(十三)

查询性能优化 优化LIMIT分页 在系统中需要进行分页操作的时候&#xff0c;我们通常会使用LIMIT加上偏移量的办法实现&#xff0c;同时加上合适的ORDER BY子句。如果有对应的索引&#xff0c;通常效率会不错&#xff0c;否则&#xff0c;MySQL需要做大量的文件排序操作。一个非…

【Python】成功解决TypeError: ‘int’ object is not iterable

【Python】成功解决TypeError: ‘int’ object is not iterable &#x1f308; 欢迎莅临我的个人主页&#x1f448;这里是我深耕Python编程、机器学习和自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;并乐于分享知识与经验的小天地&#xff01;&#x1f387; &#…

MySQL的group by与count(), *字段使用问题

文章目录 问题group by到底做了什么举个例子简单来说为什么select字段&#xff0c;count()不能和*共同使用总结 问题 这是一段摘抄自MySQL官网的文字。其大致意思是MySQL拓展了group by的使用&#xff0c;MySQL允许选择没有出现在group by中的字段。换句话说&#xff0c;标准SQ…

【Python】成功解决ZeroDivisionError: division by zero

【Python】成功解决ZeroDivisionError: division by zero &#x1f308; 欢迎莅临我的个人主页&#x1f448;这里是我深耕Python编程、机器学习和自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;并乐于分享知识与经验的小天地&#xff01;&#x1f387; &#x1f393…

【QT5.14.2】编译MQTT库example的时候报No such file or directory

【QT5.14.2】编译MQTT库example的时候报No such file or directory 前几天导师让跑一下MQTT库&#xff0c;用的5.14.2版本的QT&#xff0c;于是就上网搜了一个教程&#xff1a;https://www.bilibili.com/video/BV1dH4y1e7hG/?spm_id_from333.337.search-card.all.click&v…

Fedora的远程桌面

要在 Fedora 40 上开启远程桌面功能。 首先&#xff0c;要确保已安装 gnome-remote-desktop 和 vino 包。 这些软件包通常默认安装在 Fedora 的 GNOME 桌面环境中。 可以按照以下步骤操作&#xff1a; 1、判断电脑是否安装了 gnome-remote-desktop 和 vino 包: tomfedora:…

第十三周 5.28 三个修饰符知识点

一、abstract[抽象的] 1.abstract可以修饰类: (1&#xff09;被abstract修饰的类称为抽象类 (2) 语法:abstract class 类名{} (3) 特点:抽象类只能声明引用&#xff0c;不能创建对象 (4) 抽象类中可以定义属性和成员方法、构造方法 2.abstr…

SpringSecurity提供了哪些核心功能?

Spring Security 是一个强大且高度可定制的身份验证和访问控制框架&#xff0c;它是为保护基于Spring的应用程序而设计的。Spring Security 提供了下列核心功能&#xff1a; 1. 全面的身份验证支持 Spring Security 支持广泛的身份验证机制&#xff0c;包括表单基础认证、HTT…

【Linux】匿名管道的应用场景 --- 进程池

&#x1f466;个人主页&#xff1a;Weraphael ✍&#x1f3fb;作者简介&#xff1a;目前正在学习c和算法 ✈️专栏&#xff1a;Linux &#x1f40b; 希望大家多多支持&#xff0c;咱一起进步&#xff01;&#x1f601; 如果文章有啥瑕疵&#xff0c;希望大佬指点一二 如果文章对…

Tomcat中轻松部署Java Web项目

Tomcat 是一个广泛使用的 Java Servlet 容器和 Web 服务器&#xff0c;它允许你部署 Java Web 应用程序。以下是使用 Tomcat 部署 Java 项目的基本步骤&#xff1a; 1. 准备 Java 项目 确保你的 Java 项目是一个 Web 应用程序&#xff0c;即它包含了一个 WEB-INF 目录&#x…

Qt qtpropertybrowser使用实例(1)

属性界面实例&#xff1a; 代码如下&#xff1a; #include <QDate> #include <QLocale> #include "qtpropertymanager.h" #include "qtvariantproperty.h" #include "qttreepropertybrowser.h" int main(int argc, char *argv[]) {…