公共子序列的个数
来源:互联网 发布:淘宝注册账号打电话 编辑:程序博客网 时间:2024/05/18 09:20
http://acm.hdu.edu.cn/showproblem.php?pid=5791
给你两个数组,求公共子序列的个数。
比赛比了一会,就都有事撤了...现在开始补题,转移方程有点难想,千辛万苦想到了我还是WA了. 最后看了一下卿学姐@qscqesze的博客 ,才发现忘记处理如果dp[i][j]出现负的情况..
dp[i][j]代表A前i个数和B前j个数的公共子序列的个数。
那么dp[i][j]=dp[i][j-1]+dp[i-1][j]-dp[i-1][j-1]; 因为dp[i][j-1] 为i ,j-1的公共子序列的个数,dp[i-1][j]为i-1,j的公共子序列的个数,所以两个加起来-重复的i-1,j-1的公共子序列的个数即为dp[i][j]的公共子序列个数,当a[i]==b[j] 时,还需要dp[i][j]+=dp[i-1][j-1]+1;即 当子序列都包含a[i]的时候那就是要多出i-1,j-1的个数,和仅有a[i],a[j]的子序列。
#include <cstdio>#include <cstring>#include <iostream>using namespace std;#define Max(a,b) a>b?a:bint dp[1005][1005];int a[1005],b[1005];const int mod=1000000007;int main(){ int n,m; while(~scanf("%d%d",&n,&m)) { for(int i=1;i<=n;i++) scanf("%d",&a[i]); for(int i=1;i<=m;i++) scanf("%d",&b[i]); for(int i=0;i<=n;i++) for(int j=0;j<=m;j++) dp[i][j]=0; for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) { dp[i][j]=dp[i-1][j]+dp[i][j-1]-dp[i-1][j-1];// 可能出现负 if(a[i]==b[j]) dp[i][j]+=dp[i-1][j-1]+1; if(dp[i][j]<0) dp[i][j]+=mod; if(dp[i][j]>=mod) dp[i][j]%=mod; } printf("%d\n",dp[n][m]); }}
1 0
- 公共子序列的个数
- 两个序列中公共子序列的个数
- hdu 5795 最长公共子序列的应用-----公共子序列的个数
- Common Subsequence(公共子序列个数)
- 子序列的个数
- 子序列的个数
- 子序列的个数
- 子序列的个数
- 子序列的个数
- 最长的公共子序列
- 最长公共子串、最长公共子序列、最长回文子串、最长回文子序列、回文子串个数
- (HDU 5791)Two <DP求公共子序列的个数> 多校训练5
- 两个序列的最长公共子序列
- 子序列的个数 --- 庞果网
- 数组子序列的个数
- 【容斥原理】wikioi 1778 统计公共子序列个数
- HDU 5791 Two (dp求公共子序列个数)
- hdu5791 Two(dp求公共子序列个数)
- HTML 学习(一)之 简介
- 自定义view教你如何打造圆形的seekbar
- 好文章
- 在ubuntu linux下搭建Java Web开发环境
- hdu4465
- 公共子序列的个数
- bzoj 4569: [Scoi2016]萌萌哒 (st表+并查集)
- 使用友盟SDK提交Appstore审核被拒的常见解决方法
- 32位保护模式学习小结(2)---任务的隔离和特权级保护
- HDU 4496 D-City (并查集)
- poj 2299 Ultra-QuickSort
- 【PAT】Dijkstra+最短路径种数(★)+输出路径+卡内存
- java 快速排序 插入排序 选择排序
- 数据结构