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

【算法设计与分析】—— 分治算法

🎃个人专栏:

🐬 算法设计与分析:算法设计与分析_IT闫的博客-CSDN博客

🐳Java基础:Java基础_IT闫的博客-CSDN博客

🐋c语言:c语言_IT闫的博客-CSDN博客

🐟MySQL:数据结构_IT闫的博客-CSDN博客

🐠数据结构:​​​​​​数据结构_IT闫的博客-CSDN博客

💎C++:C++_IT闫的博客-CSDN博客

🥽C51单片机:C51单片机(STC89C516)_IT闫的博客-CSDN博客

💻基于HTML5的网页设计及应用:基于HTML5的网页设计及应用_IT闫的博客-CSDN博客​​​​​​

🥏python:python_IT闫的博客-CSDN博客

欢迎收看,希望对大家有用!

目录

🎯目的:

🎯问题及代码分析:

🥽1)二分查找的实现:

🎃代码及解析:

💻导入必要的类:

💻 创建 One 类:

💻 在 main 方法中执行二分查找:

💻 binarySearchHelper 方法实现二分查找:

🥽2)最小值问题:求n个元素的最小值:

🎃代码及解析:

💻导入必要的类:

💻 创建 One 类:

💻 在 main 方法中执行查找最小值操作:

💻 findMinmumHelper 方法实现递归查找最小值:

🥽3)幂乘问题: 给定实数a和自然数n,求a^n:

🎃代码及解析:

💻导入了Scanner类:

 💻main函数:

💻power方法:

🥽快速排序的实现:

🎃代码及解析:

💻导入了java.util.Arrays类:

 💻main方法:

💻 快速排序算法:

 💻 分割数组:

💻 交换数组中两个元素的位置:

 🎯总结分治算法的特点:

🎯注:所有完整代码:


🎯目的:

1)了解分治策略算法思想及基本原理;

2)掌握使用分治算法求解问题的一般特征;

3)掌握分解、治理的方法;

4)能够针对实际问题,能够正确的分解、治理,设计分治算法;

5)能够正确分析算法的时间复杂度和空间复杂度。

🎯问题及代码分析:

🥽1)二分查找的实现:

🎃代码及解析:

💻导入必要的类:

分析:这行代码导入了 java.util.Scanner 类,用于从控制台读取用户的输入。

import java.util.Scanner;
💻 创建 One 类:

分析:这段代码定义了一个名为 One 的公共类,并包含了 main 方法和 binarySearchHelper 方法。

public class One {public static void main(String[] args) {// ...}public static int binarySearchHelper(int[] arr, int target, int low, int high) {// ...}
}
💻 在 main 方法中执行二分查找:

分析:

        这段代码首先创建了一个 Scanner 对象 scan,用于读取用户的输入。然后,定义了一个有序整数数组 arr,其中包含了数字 1、3、4、7、8 和 10。

        接下来,通过 System.out.println 打印提示信息,要求用户输入一个在 10 以内的数字。然后,使用 scan.nextInt() 从控制台读取用户输入的目标数字,并将其存储在变量 target 中。

        最后,调用 binarySearchHelper 方法进行二分查找,传入数组 arr、目标数字 target、数组的起始索引 0 和结束索引 arr.length - 1。根据返回的索引值,打印相应的结果。

Scanner scan = new Scanner(System.in);
int[] arr = {1, 3, 4, 7, 8, 10};
System.out.println("请输入您要查找的10以内的数字:");
int target = scan.nextInt();
int index = binarySearchHelper(arr, target, 0, arr.length - 1);
if (index < 0) {System.out.println("您输入的数字查找不到!");
} else {System.out.println("输入数字对应为索引为:" + index);
}
💻 binarySearchHelper 方法实现二分查找:

分析:

这段代码定义了一个递归方法 binarySearchHelper,用于在给定的有序整数数组 arr 中查找目标数字 target。方法接受四个参数:数组 arr、目标数字 target、数组的起始索引 low 和结束索引 high

在方法中,首先检查起始索引是否大于结束索引,如果是,则表示目标数字不在数组中,返回 -1。

否则,计算中间索引 mid,并检查中间元素是否等于目标数字。如果是,返回中间索引 mid

如果中间元素大于目标数字,则递归调用 binarySearchHelper 方法,在左半部分数组中继续查找目标数字。

如果中间元素小于目标数字,则递归调用 binarySearchHelper 方法,在右半部分数组中继续查找目标数字。

这样,通过递归调用,最终会找到目标数字的索引值或返回 -1,表示目标数字不存在于数组中。

public static int binarySearchHelper(int[] arr, int target, int low, int high) {if (low > high) {return -1;}int mid = (low + high) / 2;if (arr[mid] == target) {return mid;} else if (arr[mid] > target) {return binarySearchHelper(arr, target, low, mid - 1);} else {return binarySearchHelper(arr, target, mid + 1, high);}
}


🥽2)最小值问题:求n个元素的最小值:

🎃代码及解析:

💻导入必要的类:

分析:这行代码导入了 java.util.Arrays 类,用于打印数组的内容。

import java.util.Arrays;
💻 创建 One 类:

分析:这段代码定义了一个名为 One 的公共类,并包含了 main 方法和 findMinmumHelper 方法。

public class One {public static void main(String[] args) {// ...}public static int findMinmumHelper(int[] arr, int low, int high) {// ...}
}
💻 在 main 方法中执行查找最小值操作:

分析:

这段代码首先定义了一个整型数组 arr,其中包含了一些整数。

接下来,调用 findMinmumHelper 方法进行查找最小值的操作,传入数组 arr、起始索引 0 和结束索引 arr.length - 1。将返回的最小值存储在变量 x 中。

最后,使用 System.out.println 打印数组的内容和最小值。

int[] arr = {90, 40, 50, 10, 99, 20};
int x = findMinmumHelper(arr, 0, arr.length - 1);
System.out.println("在数组" + Arrays.toString(arr));
System.out.println("最小值为:" + x);
💻 findMinmumHelper 方法实现递归查找最小值:

分析:

这段代码定义了一个递归方法 findMinmumHelper,用于在给定的数组 arr 中查找最小值。方法接受三个参数:数组 arr、起始索引 low 和结束索引 high

在方法中,首先检查起始索引和结束索引是否相等,如果相等,则表示只有一个元素,直接返回该元素作为最小值。

否则,计算中间索引 mid,并分别递归调用 findMinmumHelper 方法,在左半部分数组和右半部分数组中查找最小值。

最后,使用 Math.min 方法比较左半部分数组的最小值 leftMin 和右半部分数组的最小值 rightMin,返回较小的值作为整个数组的最小值。

public static int findMinmumHelper(int[] arr, int low, int high) {if (low == high) {return arr[low];}int mid = (low + high) / 2;int leftMin = findMinmumHelper(arr, low, mid);int rightMin = findMinmumHelper(arr, mid + 1, high);return Math.min(leftMin, rightMin);
}

🥽3)幂乘问题: 给定实数a和自然数n,求a^n:

🎃代码及解析:

💻导入了Scanner类:
import java.util.Scanner;
 💻main函数:

分析:

 在main方法中,通过Scanner类获取用户输入的a和n的值,并调用power方法计算a的n次方。

	public static void main(String[] args) {// TODO Auto-generated method stubScanner scan=new Scanner(System.in);System.out.println("请输入a的值:");int a=scan.nextInt();System.out.println("请输入数字n的值");int n=scan.nextInt();int x=power(a,n);System.out.println(a+"的"+n+"次方为:"+x);}
💻power方法:

分析:

  1. power方法是一个递归方法,其参数为底数a和指数n。如果n等于0,则返回1,因为任何数的0次方都等于1。

  2. 如果n不等于0,则继续递归计算power(a,n/2)的值,即将指数除以2,以此来减少递归次数。

  3. 如果n是偶数,则直接返回temp*temp的值,即将计算结果平方。

  4. 如果n是奇数,则需要再乘上a,即返回atemptemp的值。

  5. 最终在main方法中输出计算结果。

	public static int power(int a,int n){if(n==0) {return 1;}int temp=power(a,n/2);if(n%2==0) {return temp*temp;}else {return a*temp*temp;}}
}

🥽快速排序的实现:

🎃代码及解析:

💻导入了java.util.Arrays类:
import java.util.Arrays;
 💻main方法:

分析:

  1. 定义了一个名为One的Java类,并在其中实现了main()方法。

  2. 定义了一个整数数组arr,并初始化为{9,10,44,33,4,15}。

  3. 使用Arrays.toString()方法将数组转换为字符串,并输出排序前的序列。

  4. 调用quickSort()方法对数组进行排序。

  5. 使用Arrays.toString()方法将数组转换为字符串,并输出排序后的序列

    public static void main(String[] args) {int [] arr= {9,10,44,33,4,15};System.out.println("排序前的序列为:"+Arrays.toString(arr));quickSort(arr,0,arr.length-1);System.out.println("排序后的序列为:"+Arrays.toString(arr));}
💻 快速排序算法:

分析:

  1. 定义了一个名为quickSort()的方法,用于实现快速排序算法。该方法的参数为要排序的数组、起始位置和结束位置。如果起始位置小于结束位置,说明还需要继续排序。

  2. 调用partition()方法将数组分成两部分,返回枢轴元素的下标pivotIndex

  3. 递归调用quickSort()方法对左边的子数组进行排序,即从lowpivotIndex-1

  4. 递归调用quickSort()方法对右边的子数组进行排序,即从pivotIndexhigh

    public static void quickSort(int [] arr,int low,int high) {if(low <high) {int  pivotIndex=partition(arr,low,high);quickSort(arr, low,pivotIndex-1);quickSort(arr, pivotIndex, high);}}
 💻 分割数组:

分析:

  1. 定义了一个名为partition()的方法,用于将数组分成两部分,左边的部分小于枢轴元素,右边的部分大于等于枢轴元素。该方法的参数为要排序的数组、起始位置和结束位置。

  2. 将枢轴元素设为数组的最后一个元素arr[high]

  3. 定义一个指针i,指向数组的起始位置low-1

  4. 使用for循环遍历数组中从lowhigh-1的所有元素arr[j]

  5. 如果arr[j]小于枢轴元素pivot,则将i指针向右移动一位,并交换arr[i]arr[j]的值,以确保左边的部分都小于枢轴元素。

  6. 将枢轴元素pivotarr[i+1]交换位置,并返回i+1作为新的枢轴元素下标。

    public static int  partition(int [] arr,int low,int high) {int pivot=arr[high];int i=low -1;for(int j=low;j<high;j++) {if(arr[j]<pivot) {i++;swap(arr,i,j);}}swap(arr,i+1,high);return i+1;}
💻 交换数组中两个元素的位置:

分析:

定义了一个名为swap()的方法,用于交换数组中两个元素的位置。该方法的参数为要交换的数组和两个元素的下标。

    public static void swap(int [] arr,int i,int j) {int temp=arr[i];arr[i]=arr[j];arr[j]=temp;}


 🎯总结分治算法的特点:

分治算法是一种常用的问题解决方法,其特点如下:

  1. 分解(Divide):将原问题划分为若干个子问题,每个子问题的规模较小且结构与原问题相似。

  2. 解决(Conquer):递归地解决每个子问题。如果子问题规模足够小,可以直接求解。

  3. 合并(Combine):将子问题的解合并成原问题的解。

分治算法的特点有以下几个方面:

  1. 适用性广泛:分治算法适用于解决各种类型的问题,包括排序、搜索、图算法等。只要问题可以被划分成若干个规模较小的子问题,并且这些子问题的解可以合并成原问题的解,就可以使用分治算法。

  2. 提高效率:通过将问题划分为多个子问题并并行处理,分治算法可以显著提高问题的解决效率。子问题之间相互独立,可以同时进行计算,从而充分利用计算资源。

  3. 递归思想:分治算法通常使用递归来解决子问题。递归调用使得问题的规模逐渐减小,直到达到基本情况,然后再逐步合并子问题的解来得到原问题的解。

  4. 分解与合并的开销:分治算法的效率也受到分解和合并操作的影响。如果分解和合并操作的开销较大,可能会导致算法效率下降。

  5. 空间复杂度:分治算法通常需要额外的空间来存储子问题的解,因此在空间复杂度上可能会有一定的开销。

        总的来说,分治算法通过将问题划分为多个子问题,并递归地解决这些子问题,然后将子问题的解合并成原问题的解,从而高效地解决复杂的问题。它是一种重要的算法思想,被广泛应用于各个领域。

🎯注:所有完整代码:

🥏可以关注私信博主,博主可以给友友们发!💛

相关文章:

【算法设计与分析】—— 分治算法

&#x1f383;个人专栏&#xff1a; &#x1f42c; 算法设计与分析&#xff1a;算法设计与分析_IT闫的博客-CSDN博客 &#x1f433;Java基础&#xff1a;Java基础_IT闫的博客-CSDN博客 &#x1f40b;c语言&#xff1a;c语言_IT闫的博客-CSDN博客 &#x1f41f;MySQL&#xff1a…...

Unable to find GatewayFilterFactory with name TokenRelay

目录 问题分析解决方案参考文档开源项目微服务商城项目前后端分离项目 问题分析 Spring Cloud Gateway 网关作为代理资源服务器&#xff0c;需要将 JWT 传递给下游资源服务器&#xff0c;下面是网关的配置 spring:cloud:gateway:discovery:locator:enabled: true # 启用服务发…...

竞赛 深度学习大数据物流平台 python

文章目录 0 前言1 课题背景2 物流大数据平台的架构与设计3 智能车货匹配推荐算法的实现**1\. 问题陈述****2\. 算法模型**3\. 模型构建总览 **4 司机标签体系的搭建及算法****1\. 冷启动**2\. LSTM多标签模型算法 5 货运价格预测6 总结7 部分核心代码8 最后 0 前言 &#x1f5…...

git基础及原理相关解析

git入门 结构基本操作help提交分支git merge和git rebase对比 拉取 git文档 结构 工作区&#xff1a;电脑目录中能看到的文件暂存区&#xff1a;使用git add *操作提交文件的位置&#xff0c;一般位于.git\index&#xff0c;这个文件里面存储了当前位于暂存区的所有文件的校验…...

【Python机器学习】零基础掌握isotonic_regression等渗回归

遇到了数据不一致的困扰吗? 在市场分析、医疗研究或者其他数据密集型领域,经常会遇到一个问题:如何从一组不完全一致或者有噪音的数据中提取出有用的信息?例如,假设一家餐厅想要根据顾客的评分和消费金额来调整菜单。 顾客评分消费金额(元)顾客年龄访问次数4.21002533.…...

支持宏的文本编辑器提高生产力

场景 我们知道很多文本/代码编辑器支持宏的录制、重放、保存&#xff0c;甚至可以与快捷键命令结合的功能&#xff0c;快速实现重放宏的操作。 如果您的编辑器支持宏这项功能&#xff0c;请多使用 &#x1f603; 宏化自动步骤相当于对编辑器的自动化编程&#xff0c;宏录制可…...

JS中面向对象的程序设计

面向对象&#xff08;Object-Oriented&#xff0c;OO&#xff09;的语言有一个标志&#xff0c;那就是它们都有类的概念&#xff0c;而通过类可以创建任意多个具有相同属性和方法的对象。但在ECMAScript 中没有类的概念&#xff0c;因此它的对象也与基于类的语言中的对象有所不…...

云耀服务器L实例搭配负载均衡部署Linux 可视化宝塔面板

云耀服务器L实例搭配负载均衡部署Linux 可视化宝塔面板 1. 华为云云耀服务器L实例介绍 华为云云耀服务器L实例是一种高性能、高可靠性的云服务器实例&#xff0c;适用于大规模企业级应用、大数据分析等场景。它基于华为最新一代的硬件虚拟化技术&#xff0c;提供了更高的计算…...

mac pycharm配置autopep8

mac终端安装autopep8 pip install autopep8pycharm配置autopep8 在Pycharm中点击 File–Settings—Tools–External Tools, 点击图中绿色加号图标添加扩展工具&#xff0c;填写相关参数配置。 Name&#xff1a;Autopep8&#xff08;可以随便取&#xff09; Tools setting&…...

Vue $nextTick

我们用一个例子来说明$nextTick的作用&#xff1a; 我们用一个变量showIpt来控制input框的显示和隐藏&#xff0c;默认是隐藏。 我们点击一个按钮后显示这个输入框的同时&#xff0c;input还要自动获取焦点。 但是我们点击按钮过后并没有生效。 为什么&#xff1f;this.show…...

linux配置dns

服务器有网&#xff0c;ping IP 地址可以ping的通&#xff0c;但是ping网站域名ping不通&#xff0c;需要配置dns 使用公共dns服务器 1、设置dns服务器地址 vi /etc/resolv.conf 将谷歌的dns服务器地址添加到dns解析配置中 nameserver 8.8.8.8 nameserver 8.8.4.4 保存后&…...

12 原子性|可见性|有序性|JMM内存模型

1 并发三大特性 1.1 原子性 一个或多个操作&#xff0c;要么全部执行&#xff0c;要么全部不执行。Java中&#xff0c;对基本数据类型的变量的读取和赋值操作是原子性操作&#xff0c;但不采取任何原子性保障措施的自增操作不是原子性的&#xff0c;如&#xff1a;i public c…...

pytorch代码复现1(基础知识)

创建矩阵 全零矩阵 In [4]: import torch torch.__version__ xtorch.empty(5,3) xOut[4]: tensor([[0.0000e00, 0.0000e00, 4.6430e-23],[1.4013e-45, 1.2612e-44, 0.0000e00],[3.5733e-43, 0.0000e00, 0.0000e00],[0.0000e00, 0.0000e00, 0.0000e00],[0.0000e00, 0.0000e00, 0…...

PostGreSQL模式schema

问题引入 之前在做数据库设计时&#xff0c;经常会忽略schema模式&#xff0c;直接在数据库下的public模式下建立各类数据表。如果数据表命名不够规范&#xff0c;后期寻找某张表时就会比较麻烦。通过 所幸&#xff0c;PostgreSQL 的模式schema管理&#xff0c;可以对这个问题…...

大厂面试题-什么是JVM

JVM全称是Java虚拟机&#xff0c;在聊什么是JVM之前&#xff0c;我们不妨看⼀下这张图。 从这张图中可以看出JVM所处的位置&#xff0c;同时也能看出它两个作用&#xff1a; 1、运⾏并管理Java源码⽂件所⽣成的Class⽂件&#xff0c; 2、在不同的操作系统上安装不同的JVM&#…...

rest参数

Rest参数是ES6中新增的一个语法特性&#xff0c;也称为剩余参数。其语法形式为三个点&#xff08;...&#xff09;加上一个名称&#xff0c;用于表示函数的参数个数不确定&#xff0c;可以将多余的参数收集到一个数组中。Rest参数只能作为最后一个参数出现&#xff0c;且一个函…...

Hadoop3.0大数据处理学习3(MapReduce原理分析、日志归集、序列化机制、Yarn资源调度器)

MapReduce原理分析 什么是MapReduce 前言&#xff1a;如果想知道一堆牌中有多少张红桃&#xff0c;直接的方式是一张张的检查&#xff0c;并数出有多少张红桃。 而MapReduce的方法是&#xff0c;给所有的节点分配这堆牌&#xff0c;让每个节点计算自己手中有几张是红桃&#…...

JS DataTable中导出PDF中文乱码

JS DataTable中导出PDF中文乱码 文章目录 JS DataTable中导出PDF中文乱码一. 问题二. 原因三. vfs_fonts.js四. pdfmake.js五. 解决六.参考资料 一. 问题 二. 原因 DataTable使用pdfmake&#xff0c;pdfmake默认字体为Roboto&#xff0c;不支持中文字体。添加自己的字体&#…...

代码签名证书续费

代码签名证书的有效周期是1-3年&#xff0c;这种情况下证书到期了就要重新申请办理&#xff0c;最开始同样的申请验证步骤还要再走一遍&#xff0c;尤其是Ukey还是要CA机构重新颁发&#xff0c;还是要等待快递配送。OV代码签名证书、EV代码签名证书目前行业内统一采取Ukey存储&…...

机器学习之ROC与AUC

文章目录 定义ROC曲线&#xff1a;AUC&#xff08;Area Under the ROC Curve&#xff09;&#xff1a; 定义 ROC&#xff08;Receiver Operating Characteristic&#xff09;曲线和AUC&#xff08;Area Under the ROC Curve&#xff09;是用于评估二分类模型性能的重要工具。 …...

应用升级/灾备测试时使用guarantee 闪回点迅速回退

1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间&#xff0c; 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点&#xff0c;不需要开启数据库闪回。…...

CMake基础:构建流程详解

目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

服务器硬防的应用场景都有哪些?

服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式&#xff0c;避免服务器受到各种恶意攻击和网络威胁&#xff0c;那么&#xff0c;服务器硬防通常都会应用在哪些场景当中呢&#xff1f; 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...

多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验

一、多模态商品数据接口的技术架构 &#xff08;一&#xff09;多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如&#xff0c;当用户上传一张“蓝色连衣裙”的图片时&#xff0c;接口可自动提取图像中的颜色&#xff08;RGB值&…...

Nuxt.js 中的路由配置详解

Nuxt.js 通过其内置的路由系统简化了应用的路由配置&#xff0c;使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...

spring:实例工厂方法获取bean

spring处理使用静态工厂方法获取bean实例&#xff0c;也可以通过实例工厂方法获取bean实例。 实例工厂方法步骤如下&#xff1a; 定义实例工厂类&#xff08;Java代码&#xff09;&#xff0c;定义实例工厂&#xff08;xml&#xff09;&#xff0c;定义调用实例工厂&#xff…...

解决本地部署 SmolVLM2 大语言模型运行 flash-attn 报错

出现的问题 安装 flash-attn 会一直卡在 build 那一步或者运行报错 解决办法 是因为你安装的 flash-attn 版本没有对应上&#xff0c;所以报错&#xff0c;到 https://github.com/Dao-AILab/flash-attention/releases 下载对应版本&#xff0c;cu、torch、cp 的版本一定要对…...

【Java_EE】Spring MVC

目录 Spring Web MVC ​编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 ​编辑参数重命名 RequestParam ​编辑​编辑传递集合 RequestParam 传递JSON数据 ​编辑RequestBody ​…...

面向无人机海岸带生态系统监测的语义分割基准数据集

描述&#xff1a;海岸带生态系统的监测是维护生态平衡和可持续发展的重要任务。语义分割技术在遥感影像中的应用为海岸带生态系统的精准监测提供了有效手段。然而&#xff0c;目前该领域仍面临一个挑战&#xff0c;即缺乏公开的专门面向海岸带生态系统的语义分割基准数据集。受…...

【Android】Android 开发 ADB 常用指令

查看当前连接的设备 adb devices 连接设备 adb connect 设备IP 断开已连接的设备 adb disconnect 设备IP 安装应用 adb install 安装包的路径 卸载应用 adb uninstall 应用包名 查看已安装的应用包名 adb shell pm list packages 查看已安装的第三方应用包名 adb shell pm list…...