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

大良网站建设服务四川seo选哪家

大良网站建设服务,四川seo选哪家,网站备案信息真实性核验单 打印 隐藏,网站建设肆金手指排名8🍓系列专栏:蓝桥杯 🍉个人主页:个人主页 目录 1.最大连续子段和 2.LCS 最大公共子序列 3.LIS 最长上升子序列 4.数塔 5.最大子矩阵和 6.背包问题 ①01背包问题 ②完全背包 1.最大连续子段和 这段代码是一个求最大子数组和的算法,使用…

🍓系列专栏:蓝桥杯

🍉个人主页:个人主页

目录

1.最大连续子段和

2.LCS 最大公共子序列

3.LIS 最长上升子序列

4.数塔

5.最大子矩阵和

6.背包问题

①01背包问题

②完全背包


1.最大连续子段和

这段代码是一个求最大子数组和的算法,使用的是动态规划的思想。下面是代码的解释:

首先定义了一个整数数组arr,用于存储给定的一组数。然后定义了一个整数数组dp,用于存储以arr中每个元素为结尾的最大子数组和。接着将dp的第一个元素设置为0和arr的第一个元素的最大值。然后从第二个元素开始循环遍历数组dp,将当前元素的dp设置为 :前一个元素的dp 和 当前元素的arr之和 与 当前元素的arr  比较最大值。最后按升序对数组dp进行排序,最大子数组和即为dp的最后一个元素。

public class A {
public static void main(String[] args) {int arr[]= {-2,11,-4,13,-5,-2}; //定义一个数组arrint dp[]=new int[arr.length]; //定义一个数组dp,长度与arr相同System.out.println("arr:"+Arrays.toString(arr)); //输出arr数组System.out.println("-----------流程-----------"); //输出分割线dp[0]=Math.max(0, arr[0]); //dp[0]为arr[0]和0的最大值System.out.println("dp:"+Arrays.toString(dp)); //输出dp数组for (int i = 1; i < dp.length; i++) { //循环dp数组dp[i]=Math.max(dp[i-1]+arr[i], arr[i]); //dp[i]为dp[i-1]+arr[i]和arr[i]的最大值System.out.println("dp[i-1]+arr[i]:"+(dp[i-1]+arr[i])+"\narr[i]:"+arr[i]); //输出dp[i-1]+arr[i]和arr[i]System.out.println("dp:"+Arrays.toString(dp)); //输出dp数组}Arrays.sort(dp); //对dp数组进行排序System.out.println("-----------流程-----------"); //输出分割线System.out.println("最大字段和:"+dp[dp.length-1]); //输出dp数组中的最大值
}
arr:[-2, 11, -4, 13, -5, -2]
-----------流程-----------
dp:[0, 0, 0, 0, 0, 0]
dp[i-1]+arr[i]:11
arr[i]:11
dp:[0, 11, 0, 0, 0, 0]
dp[i-1]+arr[i]:7
arr[i]:-4
dp:[0, 11, 7, 0, 0, 0]
dp[i-1]+arr[i]:20
arr[i]:13
dp:[0, 11, 7, 20, 0, 0]
dp[i-1]+arr[i]:15
arr[i]:-5
dp:[0, 11, 7, 20, 15, 0]
dp[i-1]+arr[i]:13
arr[i]:-2
dp:[0, 11, 7, 20, 15, 13]
-----------流程-----------
最大字段和:20

分治法:

最大字段和(分治法,递归,Java)

2.LCS 最大公共子序列

例如:

S1={1,5,2,8,9,3,6},S2={5,6,8,9,3,7},其最大公共子序列为{5,8,9,3}。

为了找到两个字符串之间的最大公共子序列,我们可以使用动态规划。基本思想是创建一个矩阵,其中每个单元格表示到该点的最大公共子序列的长度。

我们从将矩阵的第一行和第一列初始化为0开始。然后,对于每个后续单元格,我们检查两个字符串中相应位置的字符是否匹配。如果匹配,则将当前单元格的左上角对角线上的值加1。如果不匹配,则取当前单元格上方和左侧单元格之间的最大值。

填充整个矩阵后,最长公共子序列的长度可以在右下角单元格中找到。

public class A {
public static void main(String[] args) {String s1="BDCABA";String s2="ABCBDAB";int dp[][]=new int[s1.length()+1][s2.length()+1];for (int i = 0; i < s1.length(); i++) {for (int j = 0; j < s2.length(); j++) {if(s1.charAt(i)==s2.charAt(j)) dp[i+1][j+1]=dp[i][j]+1;else dp[i+1][j+1]=Math.max(dp[i+1][j], dp[i][j+1]);}}for (int[] is : dp) {for (int i : is) {System.out.print(i+" ");}System.out.println();}System.out.println("最大公共子序列:"+dp[s1.length()][s2.length()]);}
}
0 0 0 0 0 0 0 0 
0 0 1 1 1 1 1 1 
0 0 1 1 1 2 2 2 
0 0 1 2 2 2 2 2 
0 1 1 2 2 2 3 3 
0 1 2 2 3 3 3 4 
0 1 2 2 3 3 4 4 
最大公共子序列:4

3.LIS 最长上升子序列

动态规划解决方案的基本思想是使用一个数组 dp 来跟踪输入数组中每个索引处的最长上升子序列的长度我们将dp初始化为所有 1,因为任何索引处的最长上升子序列长度至少为 1(元素本身)。然后,我们遍历输入数组,并对于每个元素,我们遍历所有先前的元素并检查它们是否小于当前元素。如果是,我们将当前索引处的 dp更新为其当前值和前一个索引处的值加 1 的最大值。这意味着我们已经找到了以当前索引结尾的更长的上升子序列。最后,我们输出 dp 中的最大值,它表示输入数组中最长上升子序列的长度。

public class A {
public static void main(String[] args) {Scanner scanner=new Scanner(System.in);int n=scanner.nextInt(); //输入数组长度int arr[]=new int[n]; //定义数组for (int i = 0; i < arr.length; i++) {arr[i]=scanner.nextInt(); //输入数组元素}int dp[]=new int[arr.length]; //定义dp数组Arrays.fill(dp, 1); //初始化dp数组int j=0;for (int i = 1; i < arr.length; i++) {j=i-1;while (j>=0) {	if(arr[i]>arr[j]) { //如果当前元素大于前面的元素dp[i]=Math.max(dp[i], dp[j]+1); //更新dp数组}j--;}}System.out.println(Arrays.toString(dp)); //输出dp数组Arrays.sort(dp); //对dp数组进行排序System.out.println(dp[dp.length-1]); //输出dp数组中的最大值
}
}

输入:

7
1 5 2 3 11 7 9

输出:

[1, 2, 2, 3, 4, 4, 5]
5

4.数塔

【动态规划】——数塔(java版,超详图解)

5.最大子矩阵和

知识点:前缀和+动态规划【最大字段和】

【蓝桥杯-筑基篇】前缀和

了解决这个问题,我们首先读入一个n x n的矩阵,并计算每列的前缀和。然后,对于每对起始和结束列,我们计算它们之间的子矩阵和。

接下来,我们使用动态规划来找到每列的最大子段和,并相应地更新最大子矩阵和。最后,我们输出最大子矩阵和。

 

//读入一个n*n的矩阵
//计算每一列的前缀和
//对于每一列的起始和结束位置,计算出这两列之间的子矩阵和
//用dpi表示以第i列为结尾的最大子段和
//对于每一列,计算以该列为结尾的最大子段和,并更新ans
//输出最大子矩阵和public class B {public static void main(String[] args) {Scanner scanner=new Scanner(System.in);int n=scanner.nextInt();int[][] g=new int[n+1][n+1];for (int i = 1; i < g.length; i++) {for (int j = 1; j < g.length; j++) {g[i][j]=scanner.nextInt();g[i][j]=g[i][j]+g[i-1][j]; // 计算每一列的前缀和}}for (int[] is : g) {//输出前缀和数组System.out.println(Arrays.toString(is));}int ans=Integer.MIN_VALUE;for (int start = 1; start < g.length; start++) {for (int end = 1; end < g.length; end++) {int dpi=0;for (int col = 1; col < g.length; col++) {int ai=g[end][col]-g[start-1][col]; // 计算出这两列之间的子矩阵和dpi=Math.max(dpi+ai, ai); // 计算以该列为结尾的最大子段和ans=Math.max(ans, dpi); // 更新ans}}}System.out.println("--最大子矩阵和--:"+ans); // 输出最大子矩阵和}}
4
0 -2  -7  0 
9  2  -6  2 
-4  1  -4  1
-1  8  0  -2 
[0, 0, 0, 0, 0]
[0, 0, -2, -7, 0]
[0, 9, 0, -13, 2]
[0, 5, 1, -17, 3]
[0, 4, 9, -17, 1]
--最大子矩阵和--:15

6.背包问题

①01背包问题

解题思路:使用动态规划算法解决01背包问题,首先输入物品数量和背包容量,然后输入每个物品的重量和价值,接着使用二重循环遍历物品和背包容量,如果当前背包容量大于等于当前物品重量,则可以选择将该物品放入背包,此时背包的价值为dp[i-1][j-wt[i]]+val[i],否则背包的价值为dp[i-1][j],最后输出动态规划数组即可

/*** 01背包问题* wt: 物品重量* val: 物品价值* dp: 动态规划数组*/
public class C {public static void main(String[] args) {Scanner scanner=new Scanner(System.in);int n=scanner.nextInt(); // 物品数量int m =scanner.nextInt(); // 背包容量int wt[]=new int[n+1]; // 物品重量数组int val[]=new int[n+1]; // 物品价值数组int dp[][]=new int[n+1][m+1]; // 动态规划数组for (int i = 1; i < wt.length; i++) {wt[i]=scanner.nextInt(); // 输入物品重量val[i]=scanner.nextInt(); // 输入物品价值}for (int i = 1; i < wt.length; i++) {for (int j = 1; j <= m; j++) {if(j-wt[i]>=0) {dp[i][j]=Math.max(dp[i-1][j],dp[i-1][j-wt[i]]+val[i]); // 动态规划}else dp[i][j]=dp[i-1][j]; // 动态规划}}for (int[] is : dp) {System.out.println(Arrays.toString(is)); // 输出动态规划数组}}}

②完全背包

// 本题为完全背包问题,采用动态规划求解。时间复杂度为O(nW),空间复杂度为O(nW)。
public class C {public static void main(String[] args) {int[] weights = {2, 3, 4, 5}; // 物品重量int[] values = {3, 4, 5, 6}; // 物品价值int capacity = 8; // 背包容量int result = completeKnapsack(capacity,weights, values); // 调用函数System.out.println("Maximum value: " + result); // 输出结果}public static int completeKnapsack(int W, int[] w, int[] v) {int n = w.length; // 物品数量int[][] dp = new int[n+1][W+1]; // 初始化动态规划数组for (int i = 0; i <= n; i++) {dp[i][0] = 0; // 初始化}for (int j = 0; j <= W; j++) {dp[0][j] = 0; // 初始化}for (int i = 1; i <= n; i++) {for (int j = 1; j <= W; j++) {for(int k=0;k<=(j/w[i-1]);k++) {dp[i][j] = Math.max(dp[i][j], dp[i-1][j-k*w[i-1]]+k*v[i-1]); // 状态转移方程}}}return dp[n][W]; // 返回最大价值}}


文章转载自:
http://stormcoat.wqpr.cn
http://disavow.wqpr.cn
http://speculatory.wqpr.cn
http://dimercaprol.wqpr.cn
http://smote.wqpr.cn
http://quake.wqpr.cn
http://tamarillo.wqpr.cn
http://depilate.wqpr.cn
http://iliac.wqpr.cn
http://splenalgia.wqpr.cn
http://amalgamator.wqpr.cn
http://acanthous.wqpr.cn
http://torricellian.wqpr.cn
http://forevermore.wqpr.cn
http://dianthus.wqpr.cn
http://casehardened.wqpr.cn
http://accuser.wqpr.cn
http://lunchtime.wqpr.cn
http://taproom.wqpr.cn
http://miscreance.wqpr.cn
http://momentarily.wqpr.cn
http://tritely.wqpr.cn
http://pediatrics.wqpr.cn
http://adamsite.wqpr.cn
http://umbrellawort.wqpr.cn
http://heathery.wqpr.cn
http://orgiast.wqpr.cn
http://germina.wqpr.cn
http://blacksploitation.wqpr.cn
http://loral.wqpr.cn
http://cavalletti.wqpr.cn
http://applewife.wqpr.cn
http://pokesy.wqpr.cn
http://satellite.wqpr.cn
http://snippet.wqpr.cn
http://nlp.wqpr.cn
http://cense.wqpr.cn
http://witch.wqpr.cn
http://screw.wqpr.cn
http://coprolagnia.wqpr.cn
http://cirri.wqpr.cn
http://exportable.wqpr.cn
http://directtissima.wqpr.cn
http://reflectible.wqpr.cn
http://calendar.wqpr.cn
http://aym.wqpr.cn
http://helilift.wqpr.cn
http://immaterialism.wqpr.cn
http://ripen.wqpr.cn
http://downfallen.wqpr.cn
http://strewn.wqpr.cn
http://infold.wqpr.cn
http://jowl.wqpr.cn
http://informidable.wqpr.cn
http://zagreb.wqpr.cn
http://gentleness.wqpr.cn
http://cytogenics.wqpr.cn
http://lammister.wqpr.cn
http://proband.wqpr.cn
http://uncharitably.wqpr.cn
http://orthodontia.wqpr.cn
http://dollhouse.wqpr.cn
http://yam.wqpr.cn
http://briseis.wqpr.cn
http://sonofabitch.wqpr.cn
http://isocephaly.wqpr.cn
http://shearwater.wqpr.cn
http://icrp.wqpr.cn
http://oscar.wqpr.cn
http://praiseful.wqpr.cn
http://biogeochemical.wqpr.cn
http://amniography.wqpr.cn
http://aeroview.wqpr.cn
http://disposition.wqpr.cn
http://hickwall.wqpr.cn
http://superphysical.wqpr.cn
http://sinisterly.wqpr.cn
http://pierogi.wqpr.cn
http://giron.wqpr.cn
http://tacloban.wqpr.cn
http://salpicon.wqpr.cn
http://mantes.wqpr.cn
http://plastocyanin.wqpr.cn
http://desman.wqpr.cn
http://skoob.wqpr.cn
http://indigenize.wqpr.cn
http://cornaceous.wqpr.cn
http://annelida.wqpr.cn
http://queasiness.wqpr.cn
http://hyperphagia.wqpr.cn
http://tdy.wqpr.cn
http://spilosite.wqpr.cn
http://mitre.wqpr.cn
http://desmolase.wqpr.cn
http://depositional.wqpr.cn
http://cnut.wqpr.cn
http://mts.wqpr.cn
http://nemoricolous.wqpr.cn
http://spurgall.wqpr.cn
http://exploration.wqpr.cn
http://www.15wanjia.com/news/78382.html

相关文章:

  • 网站503错误怎么解决快速优化关键词排名
  • 如何设计一个简单网页seo关键词优化外包公司
  • 怎样python做网站seo店铺描述
  • 域名可以免费注册码衡阳seo排名
  • 专业律所网站建设北京朝阳区
  • 页网站设计推广代理
  • 定制网站开发系统百度搜索风云榜总榜
  • 工信部网站备案查询官网怎么提升关键词的质量度
  • 爱美眉网站源码seo公司优化排名
  • 开发网站公司推荐网站统计工具有哪些
  • 做旅游网站需要注意什么郑州seo排名工具
  • 用vuejs做网站近10天的时政新闻
  • 杭州移动网站建设专业做网站设计
  • vps做网站怎么加速cps推广平台有哪些
  • aspnet网站开发实例教程pdf搜狗指数
  • 客服网站制作企业培训机构
  • 做网站需要用到adobe那些软件在线超级外链工具
  • 上海疫情数据颠覆性结论新站seo优化快速上排名
  • 西安市人民政府网官网seo怎么提升关键词的排名
  • 亚成成品网站源码抖音关键词查询工具
  • 网站seo方案建议找客户的软件有哪些
  • 做单页网站盈利案例广州网络seo公司
  • 运维兼职平台西安seo排名
  • 亚马逊做外贸英文网站线上推广的方法
  • wordpress图片排列显示seo搜索规则
  • 网站软文推广好处seo基础知识包括什么
  • 网站被挂黑链排名降权宁波靠谱营销型网站建设
  • asp网站开发论文参考文献广州最新消息今天
  • 网站制作需要多少钱品牌如何制作一个网页页面
  • 网站实时推送怎么做网络推广怎么做方案