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

鲁谷网站建设网站建设知名公司

鲁谷网站建设,网站建设知名公司,中国有哪些网站,wordpress 动漫主题1.DP22 最长回文子序列 1.题目 2.解析 这是一个区间dp问题,我们让dp[i][j]表示在区间[i,j]内的最长子序列长度,如图: 3.代码 public class LongestArr {//DP22 最长回文子序列public static void main(String[] args) {Scanner…

1.DP22 最长回文子序列

1.题目

2.解析

这是一个区间dp问题,我们让dp[i][j]表示在区间[i,j]内的最长子序列长度,如图:

3.代码

public class LongestArr {//DP22 最长回文子序列public static void main(String[] args) {Scanner in = new Scanner(System.in);char[] arr = in.next().toCharArray();//让dp[i][j]表示在区间i,j内的最长子序列长度//dp[i][j]=当arr[i]==arr[j]时为dp[i+1][j-1]+2;//当arr[i]!=arr[j]时因为arr[i]和arr[j]其一肯定//有一个不在子序列中,所以dp[i][j]=Math.max(dp[i+1][j],dp[i][j-1]);int n = arr.length;int[][] dp = new int[n][n];//初始化,当i=j时为1,i>j时为0(因为长度为负数不能算有字符串,i<j时要计算,最后取dp[0][n-1])for (int i = n - 1; i >= 0; i--) {for (int j = i; j < n; j++) {if (j == i) {dp[i][j] = 1;} else {if (arr[i] == arr[j]) {dp[i][j] = dp[i + 1][j - 1] + 2;} else {dp[i][j] = Math.max(dp[i + 1][j], dp[i][j - 1]);}}}}System.out.print(dp[0][n - 1]);}
}

2.数组变换

1.题目

2.解析

那么综上所述我们只要知道最大的数是否能和其他数匹配就行,但是问题来了,怎么知道它们是否匹配呢。我们可以先让最大数除以另一个想要与之匹配的数,若除不尽,则不能匹配,若除尽,则判断商是否为2的n次方。这里除尽除不尽用%小数来表示。那怎么判断是否为2的n次方呢,这里有三种方式,一种是暴力求法,让这个数无限/2,%2即可,第二种是lowbit算法,判断x-(x&-x)是否为0,第三种就是之前做过的判断1的位数的位运算方法,因为我们只需要判断是否只有1位1,所以,判断x&(x-1)是否为0即可。下文采用的是lowbit算法。

3.代码

public class demo2 {//数组变换public static void main(String[] args) {Scanner in = new Scanner(System.in);//取最大的数和其余的数做比较,看这个数能否变成这个最大的数//输入时判断最大数int n = in.nextInt();int max = 0;int[] arr = new int[n];for (int i = 0; i < n; i++) {int tem = in.nextInt();if (i == 0) {max = tem;} else max = Math.max(tem, max);arr[i] = tem;}for (int i = 0; i < n; i++) {//判断能否变为最大的数if (max % arr[i] == 0) {int s = max / arr[i];if (s - (s & -s) != 0) {System.out.print("NO");return;}} else {System.out.print("NO");return;}}System.out.print("YES");}
}

3.DP10 最大子矩阵

1.题目


2.解析

在判断矩阵最大大小之前,我们肯定要枚举所有矩阵,如图:

for(int x1=0;x1<n;x1++) {for(int y1=0;y1<n;y1++) {for(int x2=x1;x2<n;x2++) {for(int y2=y1;y2<n;y2++) {//这里写判断大小的一系列逻辑                    }}}

我们要计算矩阵内部的和,有两种方法,一种是暴力解法,用两层for循环来一个一个加起来,但是这样时间复杂度就是O(n^2)加上外部循环就是 O(n^6)。所以我们用第二种方法,前缀和如图:

那么如何使用呢?如图:

最后比较最大值就行


3.代码

 public static void main(String[] args) {Scanner in = new Scanner(System.in);int n=in.nextInt();//输入数据int[][] arr=new int[n][n];for(int i=0;i<n;i++) {for(int j=0;j<n;j++) {arr[i][j]=in.nextInt();}}//用二维dp计算前缀和//dp[i-1][j-1]表示(0,0)到(i,j)的前缀和大小//初始化int[][] dp=new int[n+1][n+1];for(int i=1;i<=n;i++) {for(int j=1;j<=n;j++) {dp[i][j]=dp[i][j-1]+dp[i-1][j]-dp[i-1][j-1]+arr[i-1][j-1];}}//枚举每一块矩阵int max=-0x3f3f3f3f;for(int x1=0;x1<n;x1++) {for(int y1=0;y1<n;y1++) {for(int x2=x1;x2<n;x2++) {for(int y2=y1;y2<n;y2++) {int tem=dp[y2+1][x2+1]-dp[y2+1][x1]-dp[y1][x2+1]+dp[y1][x1];if(max<tem) {max=tem;}}}}}System.out.print(max);}

http://www.yayakq.cn/news/556907/

相关文章:

  • 旅游企业网站建设工作的通知投资公司的钱从哪里来
  • 企业展示型网站建设有什么好的建站公司
  • 北京建设执业注册中心网站公司建设网站的费用吗
  • 中国建设网官方网站建筑工程税率网站备案都有哪些
  • 非洲外贸平台有哪些网站优化 kps
  • 4网站建设哪里好点保安公司的网站设计比较好的
  • 门户网站有哪些工商注册深圳
  • 做哪类网站没有版权问题网站建设赶集网
  • 实训课做一个网站怎么做wordpress紫色大气淘宝客主题
  • 长沙做网站最好的公司会qt怎么做网站
  • 博客类网站怎么做如何做公司自己的网站
  • 专门做男士用品的网站电子类网站建设
  • 发软文在哪个网站找文章最好wordpress主题lenews
  • 我想建立个网站怎么弄想做苗木生意网站怎么怎么做
  • 武威网站制作公司哪个好网站流量 次
  • 旅游网站建设需求分析寮步网站制作
  • 做网站黑吃黑是什么罪学ui有前途吗
  • 网站导入开发手机app游戏公司
  • 合肥公司网站建设价格低北滘网站建设
  • 免费网站教程三河网站seo
  • 建设部质量监督官方网站网站开发属于软件开发服务吗
  • 杭州网站建设蒙特python 网站开发 视频
  • 建设银行哪个是假网站网站建设 兼职
  • 东莞网络建设推广长沙seo网络营销推广
  • 医疗网站备案要怎么做 需要准备什么材料哪个代运营公司比较好
  • 黄骅网站湖北阳新县建设局网站
  • 比比西旅游网站建设营销网站建设服务平台
  • 数据图表展示网站肥东建设局网站
  • 自己做APP需要网站吗jsp做的当当网站的文档
  • 淘宝做seo要建网站吗rtk建站教程