探索经典算法问题与解决方案
探索经典算法问题与解决方案
在计算机科学领域,有许多经典算法问题需要我们思考和解决。本文将深入介绍一些著名的经典算法问题,包括旅行商问题、背包问题的变种、N皇后问题、钢条切割问题、最大子数组和问题、最长公共子串问题以及矩阵连乘问题,并提供完整的Java代码示例。
1. 旅行商问题(TSP)
旅行商问题是一种组合优化问题,要求在给定的一组城市和距离情况下,找到一条最短的路径,使得每个城市恰好被访问一次,最终回到出发城市。
public class TravelingSalesmanProblem {static int[][] graph = {{0, 29, 20, 21},{29, 0, 15, 18},{20, 15, 0, 16},{21, 18, 16, 0}};static int tsp(int mask, int pos) {if (mask == (1 << graph.length) - 1) {return graph[pos][0];}int minCost = Integer.MAX_VALUE;for (int city = 0; city < graph.length; city++) {if ((mask & (1 << city)) == 0) {int newMask = mask | (1 << city);int cost = graph[pos][city] + tsp(newMask, city);minCost = Math.min(minCost, cost);}}return minCost;}public static void main(String[] args) {System.out.println("最短路径长度:" + tsp(1, 0));}
}
2. 背包问题的变种
背包问题是指在给定容量的背包和一组物品的情况下,选择不同的物品放入背包中以达到最大价值。这里我们考虑两种背包问题的变种:多重背包问题和无限背包问题。
2.1 多重背包问题
public class MultipleKnapsackProblem {static int knapsack(int[] values, int[] weights, int[] quantities, int capacity) {int n = values.length;int[][] dp = new int[n + 1][capacity + 1];for (int i = 1; i <= n; i++) {for (int w = 1; w <= capacity; w++) {dp[i][w] = dp[i - 1][w];for (int k = 1; k <= quantities[i - 1] && k * weights[i - 1] <= w; k++) {dp[i][w] = Math.max(dp[i][w], dp[i - 1][w - k * weights[i - 1]] + k * values[i - 1]);}}}return dp[n][capacity];}public static void main(String[] args) {int[] values = {10, 30, 20};int[] weights = {5, 10, 15};int[] quantities = {2, 2, 1};int capacity = 50;System.out.println("最大价值:" + knapsack(values, weights, quantities, capacity));}
}
2.2 无限背包问题
public class UnboundedKnapsackProblem {static int knapsack(int[] values, int[] weights, int capacity) {int n = values.length;int[] dp = new int[capacity + 1];for (int w = 1; w <= capacity; w++) {for (int i = 0; i < n; i++) {if (weights[i] <= w) {dp[w] = Math.max(dp[w], dp[w - weights[i]] + values[i]);}}}return dp[capacity];}public static void main(String[] args) {int[] values = {10, 30, 20};int[] weights = {5, 10, 15};int capacity = 50;System.out.println("最大价值:" + knapsack(values, weights, capacity));}
}
3. N皇后问题
N皇后问题是指在N×N的棋盘上放置N个皇后,使得任意两个皇后都不能互相攻击。攻击包括在同一行、同一列或同一对角线上。
public class NQueensProblem {static int n = 8;static boolean isSafe(int[][] board, int row, int col) {for (int i = 0; i < col; i++) {if (board[row][i] == 1) {return false;}}for (int i = row, j = col; i >= 0 && j >= 0; i--, j--) {if (board[i][j] == 1) {return false;}}for (int i = row, j = col; i < n && j >= 0; i++, j--) {if (board[i][j] == 1) {return false;}}return true;}static boolean solveNQueensUtil(int[][] board, int col) {if (col >= n) {return true;}for (int i = 0; i < n; i++) {if (isSafe(board, i, col)) {board[i][col] = 1;if (solveNQueensUtil(board, col + 1)) {return true;}board[i][col] = 0;}}return false;}static void printSolution(int[][] board) {for (int i = 0; i < n; i++) {for (int j =0; j < n; j++) {System.out.print(board[i][j] + " ");}System.out.println();}}public static void main(String[] args) {int[][] board = new int[n][n];if (!solveNQueensUtil(board, 0)) {System.out.println("解不存在");} else {printSolution(board);}}
}
4. 钢条切割问题
钢条切割问题是指给定一根长度为n的钢条和一个价格表,求解将钢条切割成若干段使得总收益最大。
public class RodCuttingProblem {static int cutRod(int[] prices, int n) {int[] dp = new int[n + 1];dp[0] = 0;for (int i = 1; i <= n; i++) {int maxPrice = Integer.MIN_VALUE;for (int j = 1; j <= i; j++) {maxPrice = Math.max(maxPrice, prices[j - 1] + dp[i - j]);}dp[i] = maxPrice;}return dp[n];}public static void main(String[] args) {int[] prices = {1, 5, 8, 9, 10, 17, 17, 20};int n = 8;System.out.println("最大收益:" + cutRod(prices, n));}
}
5. 最大子数组和问题
最大子数组和问题是指在给定整数数组中,找到一个连续的子数组,使得该子数组的和最大。
public class MaximumSubarrayProblem {static int maxSubArray(int[] nums) {int maxSum = nums[0];int currentSum = nums[0];for (int i = 1; i < nums.length; i++) {currentSum = Math.max(nums[i], currentSum + nums[i]);maxSum = Math.max(maxSum, currentSum);}return maxSum;}public static void main(String[] args) {int[] nums = {-2, 1, -3, 4, -1, 2, 1, -5, 4};System.out.println("最大子数组和:" + maxSubArray(nums));}
}
6. 最长公共子串问题
最长公共子串问题是指在两个字符串中找到最长的连续子串,使得两个字符串都包含该子串。
public class LongestCommonSubstringProblem {static int longestCommonSubstring(String text1, String text2) {int m = text1.length();int n = text2.length();int[][] dp = new int[m + 1][n + 1];int maxLength = 0;for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {if (text1.charAt(i - 1) == text2.charAt(j - 1)) {dp[i][j] = dp[i - 1][j - 1] + 1;maxLength = Math.max(maxLength, dp[i][j]);}}}return maxLength;}public static void main(String[] args) {String text1 = "ABABC";String text2 = "BABCBA";System.out.println("最长公共子串长度:" + longestCommonSubstring(text1, text2));}
}
7. 矩阵连乘问题
矩阵连乘问题是指在给定一系列矩阵的情况下,找到一种矩阵乘法的顺序,使得计算总的乘法次数最少。
public class MatrixChainMultiplication {static int matrixChainOrder(int[] dimensions) {int n = dimensions.length;int[][] dp = new int[n][n];for (int len = 2; len < n; len++) {for (int i = 1; i < n - len + 1; i++) {int j = i + len - 1;dp[i][j] = Integer.MAX_VALUE;for (int k = i; k <= j - 1; k++) {int cost = dp[i][k] + dp[k + 1][j] + dimensions[i - 1] * dimensions[k] * dimensions[j];dp[i][j] = Math.min(dp[i][j], cost);}}}return dp[1][n - 1];}public static void main(String[] args) {int[] dimensions = {10, 30, 5, 60};System.out.println("最少乘法次数:" + matrixChainOrder(dimensions));}
}
总结
经典算法问题是计算机科学领域中的重要部分,通过深入研究和理解这些问题的解决方案,我们可以更好地理解算法设计的原则和思想。本文详细介绍了旅行商问题、背包问题的变种、N皇后问题、钢条切割问题、最大子数组和问题、最长公共子串问题以及矩阵连乘问题,每个问题都配有完整的Java代码示例,希望能够帮助您更好地掌握这些经典算法问题的解决方法。
相关文章:
探索经典算法问题与解决方案
探索经典算法问题与解决方案 在计算机科学领域,有许多经典算法问题需要我们思考和解决。本文将深入介绍一些著名的经典算法问题,包括旅行商问题、背包问题的变种、N皇后问题、钢条切割问题、最大子数组和问题、最长公共子串问题以及矩阵连乘问题&#x…...
【Linux】DNS系统,ICMP协议,NAPT技术
遏制自己内心的知识优越感,才能让你发自内心的去尊重他人,避免狂妄自大,才能让你不断的丰富自己的内心。 文章目录 一、DNS系统1.DNS服务器返回域名对应的ip2.使用dig工具分析DNS过程3.浏览器中输入url后发生的事情? 二、ICMP协议…...
BI技巧丨Window应用之同环比
白茶曾介绍过OFFSET可以用来解决同环比的问题,其实微软最近推出的开窗函数WINDOW也可以用来解决同环比。 WINDOW函数基础语法 WINDOW ( from[, from_type], to[, to_type][, <relation>][, <orderBy>][, <blanks>][, <partitionBy>][, &l…...
【Mac】编译Spring 源码和Idea导入
今天我们开始Spring源码的阅读之旅。阅读Spring的源码的第一步当然是编译Spring源码。首先我们要去GitHub上将spring源码给clone下来。 笔者编译环境如下: Spring版本:5.28 https://github.com/spring-projects/spring-framework/tree/v5.2.8.RELEASE …...
手把手教你用 ANSYS workbench
ANSYS Workbench ANSYS Workbench是一款基于有限元分析(FEA)的工程仿真软件。其基本概念包括: 工作区(Workspace):工程仿真模块都在此区域内,包括几何建模、网格划分、边界条件设置、分析求解等…...
Kotlin开发笔记:协程基础
Kotlin开发笔记:协程基础 导语 本章内容与书的第十五章相关,主要介绍与协程相关的知识。总的来说,本文将会介绍Kotlin中关于异步编程的内容,主要就是与协程有关。在Kotlin中协程是利用continuations数据结构构建的,用…...
自学设计模式(简单工厂模式、工厂模式、抽象工厂模式)
使用工厂模式来生产某类对象(代码简化且容易维护,类之间有血缘关系,可以通过工厂类进行生产); 简单工厂模式(用于创建简单对象) 对于简单工厂模式,需要的工厂类只有一个࿱…...
NFS:使⽤ NFS 为远程客户端提供共享文件系统
写在前面 分享一些 nfs 搭建的笔记考试顺便整理内容涉及 nfs 服务端客户端的搭建配置理解不足小伙伴帮忙指正 对每个人而言,真正的职责只有一个:找到自我。然后在心中坚守其一生,全心全意,永不停息。所有其它的路都是不完整的&…...
2022-kaggle-nlp赛事:Feedback Prize - English Language Learning(超多注释讲解)
2022-kaggle-nlp赛事:Feedback Prize - English Language Learning 零、比赛介绍 比赛地址Feedback Prize - English Language Learning | Kaggle 0.1 比赛目标 写作是一项基本技能。可惜很少学生能够磨练,因为学校很少布置写作任务。学习英语作为第…...
第十三课 宾语从句
文章目录 前言一、宾语从句1、主语及物动词宾语从句2、主语双宾动词间接宾语直接宾语3、主语特定及物动词宾语从句(作宾语)宾补4、主语be某些形容词宾语从句5、动词不定式后面的宾语从句6、动名词后面的宾语从句7、介词后面的宾语从句9、间接引语 前言 一…...
Docker容器与虚拟化技术:GitHub账户注册
目录 一、实验 1.GitHub 一、实验 1.GitHub (1)GitHub是一个面向开源及私有软件项目的托管平台,因为只支持Git作为唯一的版本库格式进行托管,故名GitHub。 (2)官网 GitHub: Let’s build from here …...
thinkphp安装workman
需要加版本,版本太高了不行 composer require topthink/think-worker1.0.*...
L1-036 A乘以B(Python实现) 测试点全过
题目 看我没骗你吧 —— 这是一道你可以在 10 秒内完成的题:给定两个绝对值不超过 100 的整数 A 和 B,输出 A 乘以 B 的值。 输入格式 输入在第一行给出两个整数 A 和 B ( − 100 ≤ A , B ≤ 100 ) A 和 B(−100≤…...
代码随想录第五十三天
代码随想录第五十三天 Leetcode 1143. 最长公共子序列Leetcode 1035. 不相交的线Leetcode 53. 最大子数组和 Leetcode 1143. 最长公共子序列 题目链接: 最长公共子序列 自己的思路:没想出来!!! 正确思路:首先这道题由于是涉及到了两个数组&…...
cmd - 如何在不重启的情况下让修改后的hosts生效
cmd - 如何在不重启的情况下让修改后的hosts生效 亲测有效 一般在修改了hosts文件后,需要重启电脑才能生效;其实可以不通过重启电脑也可以令其生效,方法如下: 打开cmd窗口输入ipconfig /flushdns,然后回车。…...
echarts实现双x轴并且分组滚动效果
var myChart echarts.init(document.getElementById(allOutPut1));var option {legend: {itemHeight: 10, // 图例icon高度itemWidth: 16, // 图例icon宽度icon:rect,//设置为矩形top:2%,right:10%,},tooltip: {trigger: axis,axisPointer: {type: shadow},textStyle: {fontS…...
UE4 地形编辑基础知识 学习笔记
之前自己写过这样的功能,今天看到一个UE现成的 点击地形,选择样条 按住CTRL键点击屏幕中某一个点会在场景内生成一个这样的图标 再点两次,会生成B样条的绿线条 点击号再选择一个模型,会生成对应的链条状的mesh 拉高最远处的一个图…...
AcWing算法提高课-5.5.2最大公约数
宣传一下 算法提高课整理 CSDN个人主页:更好的阅读体验 原题链接 题目描述 给定整数 N N N,求 1 ≤ x , y ≤ N 1 \le x,y \le N 1≤x,y≤N 且 gcd ( x , y ) \gcd(x,y) gcd(x,y) 为素数的数对 ( x , y ) (x,y) (x,y) 有多少对。 输入格式 输…...
Kubernetes-CKA考题详解
Kubernetes-CKA考题详解 考前须知:考试环境说明第一题:RBAC(4%)第二题:指定node设置为不可用(4%)第三题:升级kubernetes节点(7%)第四题:etcd备份还原(7%)第五题:创建NetworkPolicy(7%)第六题:创建svc(7%)第七题:创建ingress资源(7%)第八题:扩展deployme…...
不同版本.net引用同一个项目
项目文件.csproj文件内容如下: 重点是:不能有其他的 netstandard2;net40;net45;net46;net6 <Project Sdk"Microsoft.NET.Sdk"><PropertyGroup><TargetFrameworks>netstandard2;net40;net45;net46;net6</TargetFrame…...
UE5 学习系列(二)用户操作界面及介绍
这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…...
无法与IP建立连接,未能下载VSCode服务器
如题,在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈,发现是VSCode版本自动更新惹的祸!!! 在VSCode的帮助->关于这里发现前几天VSCode自动更新了,我的版本号变成了1.100.3 才导致了远程连接出…...
关于nvm与node.js
1 安装nvm 安装过程中手动修改 nvm的安装路径, 以及修改 通过nvm安装node后正在使用的node的存放目录【这句话可能难以理解,但接着往下看你就了然了】 2 修改nvm中settings.txt文件配置 nvm安装成功后,通常在该文件中会出现以下配置&…...
服务器硬防的应用场景都有哪些?
服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式,避免服务器受到各种恶意攻击和网络威胁,那么,服务器硬防通常都会应用在哪些场景当中呢? 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...
令牌桶 滑动窗口->限流 分布式信号量->限并发的原理 lua脚本分析介绍
文章目录 前言限流限制并发的实际理解限流令牌桶代码实现结果分析令牌桶lua的模拟实现原理总结: 滑动窗口代码实现结果分析lua脚本原理解析 限并发分布式信号量代码实现结果分析lua脚本实现原理 双注解去实现限流 并发结果分析: 实际业务去理解体会统一注…...
【论文阅读28】-CNN-BiLSTM-Attention-(2024)
本文把滑坡位移序列拆开、筛优质因子,再用 CNN-BiLSTM-Attention 来动态预测每个子序列,最后重构出总位移,预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵(S…...
Mobile ALOHA全身模仿学习
一、题目 Mobile ALOHA:通过低成本全身远程操作学习双手移动操作 传统模仿学习(Imitation Learning)缺点:聚焦与桌面操作,缺乏通用任务所需的移动性和灵活性 本论文优点:(1)在ALOHA…...
【Linux】Linux 系统默认的目录及作用说明
博主介绍:✌全网粉丝23W,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…...
在树莓派上添加音频输入设备的几种方法
在树莓派上添加音频输入设备可以通过以下步骤完成,具体方法取决于设备类型(如USB麦克风、3.5mm接口麦克风或HDMI音频输入)。以下是详细指南: 1. 连接音频输入设备 USB麦克风/声卡:直接插入树莓派的USB接口。3.5mm麦克…...
实战三:开发网页端界面完成黑白视频转为彩色视频
一、需求描述 设计一个简单的视频上色应用,用户可以通过网页界面上传黑白视频,系统会自动将其转换为彩色视频。整个过程对用户来说非常简单直观,不需要了解技术细节。 效果图 二、实现思路 总体思路: 用户通过Gradio界面上…...
