OJ1306-最长公共子上升序列【dp】

前言

这是一道比较久之前的题了,之前没做完。不过这次不是因为我改了,而是数据改了(可能之前有问题),然后偶然今天翻的时候就发现自己对了QAQ。


题目

OJ1306
就是给出两个序列,求出这两个序列中公共的最长的子上升序列。


解题思路

这里用的是比较慢的方法。就是4重循环。


代码

#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int b[501][501],b2[501][501],f[501][501],a1[501],a2[501],max1,max2,m1,m2;
bool ok[501][501];
void print(int x,int y)
{if (b[x][y]==0 && b2[x][y]==0 || x<=0 || y<=0) {printf("%d ",a1[x]);return;}print(x-b[x][y],y-b2[x][y]);printf("%d ",a1[x]);
}//输出序列
int main()
{scanf("%d",&m1);for (int i=1;i<=m1;i++) scanf("%d",&a1[i]);scanf("%d",&m2);for (int i=1;i<=m2;i++) scanf("%d",&a2[i]); //输入for (int i=1;i<=m1;i++)//枚举第一个序列开头{for (int j=1;j<=m2;j++)//枚举第二个开头{f[i][j]=1;//改变if (f[i][j]<f[i-1][j]){f[i][j]=f[i-1][j];b[i][j]=1;b2[i][j]=0;}//判断路径输出if (f[i][j]<f[i][j-1]){f[i][j]=f[i][j+1];b[i][j]=0;b2[i][j]=1;}//判断路径输出if (a1[i]==a2[j])//开头相同{for (int k=1;k<i;k++)for (int k2=1;k2<j;k2++)//往下枚举{if (f[i][j]<=f[i-k][j-k2]+1 && a1[i]>a1[i-k] && a1[i-k]==a2[j-k2]){f[i][j]=f[i-k][j-k2]+1;//动态转移b[i][j]=k;b2[i][j]=k2;//记录过程}}if (f[max1][max2]<f[i][j]) {max1=i;max2=j;}//改变最大值}else {ok[i][j]=true;}//输出防止输出没有的数}}printf("%d\n",f[max1][max2]);if (f[max1][max2]!=0){print(max1,max2);}
}

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

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

相关文章

多线程三种同步方式(模拟银行取款)

方法一&#xff1a;同步代码块 Accoun package com.bjsxt.synch1;/*** 银行账户类*/ public class Account {private int balance 600;//余额/*** 取款* param money*/public void withDraw(int money){this.balance this.balance -money;}/*** 查看余额* return*/public i…

今天就唠叨唠叨吧……

点击上方蓝色关注我们&#xff01;看书这个爱好是从去年年底开始的。看关于教育教学管理类型的书籍是从今年前半年开始的&#xff0c;有好些书都是王晓春老师写的&#xff0c;例如《做一个专业的班主任》、《问题学生诊疗手册》《今天怎样做教师》&#xff0c;每本书都有不一样…

利用redis保存验证码并设置过期时间

package com.atguigu.jedis;import redis.clients.jedis.Jedis;import java.util.Random;public class PhoneCode {public static void main(String[] args) {//模拟验证码发送verifyCode("13678765435");//模拟验证码校验//getRedisCode("13678765435",&q…

洛谷P2085ssl1411OJ1370-最小函数值【堆,贪心】

前言 有一个东西卡了我一会 折叠N*或N 正整数集 (由全体正整数组成的集合) N*:{1,2,3,…,n,…} 题目 洛谷P2085 OJ1370 给出n个ai,bi,ci。定义一个函数 fi(x)aix2bixci(x∈N∗)fi(x)aix2bixci(x∈N∗)然后求最小的m个数解题思路 这道题比较简单&#xff0c;一下就想到了…

如何轻松愉快的理解条件随机场(CRF)

转载自 如何轻松愉快的理解条件随机场&#xff08;CRF&#xff09; 如何轻松愉快的理解条件随机场&#xff08;CRF&#xff09;&#xff1f; 理解条件随机场最好的办法就是用一个现实的例子来说明它。 但是目前中文的条件随机场文章鲜有这样干的&#xff0c;可能写文章的人…

ASP.NET Core MVC 控制器创建与依赖注入

在我最后一篇关于 ASP.NET Core 释放IDsiposable对象的文章&#xff08;中文、英文原文&#xff09;中&#xff0c;Mark Rendle 指出&#xff0c;MVC 控制器在请求结束时也会释放资源。乍一看&#xff0c;此范围内的资源在请求结束时会释放似乎是显而易见的&#xff0c;但是 MV…

多线程的线程通信(生产消费)

消费者线程 package com.bjsxt.commu5;/*** 消费者线程*/ public class ConsumeRunnable implements Runnable {//private Product product new Product();private Product product;private Object obj new Object();public ConsumeRunnable() {}public ConsumeRunnable(Pr…

19级:一天一瞬间

点击上方蓝色关注我们&#xff01;3班的KTV项目周期为两周&#xff0c;目前时间将近一周&#xff0c;除李磊小组进度超出之外&#xff0c;其余四个小组的进度都属正常。上午大致的将每个小组的前台功能过了一遍&#xff0c;刘文瑞小组还剩几个点歌功能未实现&#xff0c;整体的…

数组与集合相互转换

数组Array与集合List相互转化有两种方式&#xff0c;一种是自己手动转化&#xff0c;一种是直接使用集合或数组自带的方法转化 数组转化集合&#xff1a; 方法一&#xff1a;手动转化 List<String> list new ArrayList<>(); String[] array new String[] {"…

拥抱.NET Core系列:依赖注入(2)

上一篇“拥抱.NET Core系列&#xff1a;依赖注入&#xff08;1&#xff09;大体介绍了服务注册、获取和生命周期&#xff0c;这一篇来做一些补充。由于内容跨度大&#xff08;.NET Core、ASP.NET Core&#xff09;&#xff0c;所以文章并不是非常的贯穿&#xff0c;大家可以挑着…

使用Docker 实现微服务并搭建博客,一文全掌握

转载自 使用Docker 实现微服务并搭建博客&#xff0c;一文全掌握 Docker 是一个容器工具&#xff0c;提供虚拟环境。很多人认为&#xff0c;它改变了我们对软件的认识。 本文&#xff0c;通过搭建一个博客的例子&#xff0c;来介绍如何使用Docker实现微服务。 站在 Docker …

失望至极……

点击上方蓝色关注我们&#xff01;

【2018.3.10】模拟赛之一-ssl2574Closest【深搜】

目录地址 前言 感谢黎某儿&#xff08;划掉&#xff09;教我这道题☆⌒(*&#xff3e;-゜)v。 正题 给出两个n位数A,B。我们需要找到两个最近的靠近A的n位数&#xff08;第一个比A大或与A相等&#xff0c;第二个严格比A小&#xff09;&#xff0c;使得它们的十进制表示是B中…

什么是mysql的主从复制?

​ MySQL 主从复制是指数据可以从一个MySQL数据库服务器主节点复制到一个或多个从节点。MySQL 默认采用异步复制方式&#xff0c;这样从节点不用一直访问主服务器来更新自己的数据&#xff0c;数据的更新可以在远程连接上进行&#xff0c;从节点可以复制主数据库中的所有数据库…

asp.net core新特性(1):TagHelper

进步&#xff0c;才是人应该有的现象。—— 雨果 今天开始&#xff0c;我就来说说asp.net core的新特性&#xff0c;今天就说说TagHelper标签助手。虽然学习.net&#xff0c;最有帮助的就是microsoft的官方说明文档了&#xff0c;里面把一些使用说明都写的非常清楚&#xff0c;…

Java中的事务——全局事务与本地事务

转载自 Java中的事务——全局事务与本地事务 在上一篇文章中说到过&#xff0c;Java事务的类型有三种&#xff1a;JDBC事务、JTA(Java Transaction API)事务、容器事务。 这是从事务的实现角度区分的&#xff0c;本文从另外一个角度来再次区分一下Java中的事务。站在事务管…

SSM整合简单登录案例

[1] 在数据库中创建用户信息表 [2] 搭建SSM开发环境 使用idea创建登录功能的web项目 在web-inf目录下创建lib文件夹&#xff0c;并导入SSM的jar包. 在src下创建MVC的包结构 在src下创建并配置SSM的xml文件 ① applicationcontext.xml <?xml version"1.0"…

19级、20级:班级日常分享,一天一瞬间

点击上方蓝色关注我们&#xff01;由于近期班级里面总是有或大或小的问题&#xff0c;所以就和丁老师商量的制定了长达29条的班规&#xff0c;昨天利用下午上课的时间在班内逐条讲解。因为班规是以安全、学习、道德以及身心健康为中心出发的&#xff0c;所以条条都合理&#xf…

同步VS异步

同步异步 &#xff0c; 举个例子来说&#xff0c;一家餐厅吧来了5个客人&#xff0c;同步的意思就是说&#xff0c;来第一个点菜&#xff0c;点了个鱼&#xff0c;好&#xff0c; 厨师去捉鱼杀鱼&#xff0c;过了半小时鱼好了给第一位客人&#xff0c;开始下位一位客人&#xf…

【2018.3.10】模拟赛之二-ssl2575 给出字符串【字符串】

目录地址 前言 其实可以不用哈希的&#xff0c;好像会更慢。还有之前看错题了&#xff0c;所以会有些奇怪的地方 正题 给出一个字符串&#xff0c;求最长的至少出现过两次的子串 输入输出&#xff08;需要自取&#xff09; Input 输入文件ygas.in第一行包含该字符串。数据…