主题链接:点击打开链接

意甲冠军:

特定n长序列

给定k长序列

求LCIS并输出这个子序列

如有多解输出随意解。。

= - = 敲的时候听着小曲儿pre的含义还没有想清楚,万万没想到就过了。。。

  1. #include<stdio.h>
  2. #include<iostream>
  3. #include<string.h>
  4. #include<set>
  5. #include<vector>
  6. #include<map>
  7. #include<math.h>
  8. #include<string>
  9. #include<stdlib.h>
  10. #include<algorithm>
  11. using namespace std;
  12. #define N 505
  13. int a[N],s[N];
  14. int n, k;
  15. int dp[N][N];
  16. int pre[N][N][2];
  17. int is[N][N];
  18. vector<int>G;
  19. int main(){
  20. int i,j,co;
  21. while(~scanf("%d",&n)){
  22. G.clear();
  23. for(i=1;i<=n;i++)scanf("%d",&a[i]);
  24. scanf("%d",&k);
  25. for(i=1;i<=k;i++)scanf("%d",&s[i]);
  26. memset(dp, 0, sizeof dp);
  27. memset(pre, 0, sizeof pre);
  28. memset(is, 0, sizeof is);
  29. for(i=1;i<=n;i++) {
  30. int maxx = 0;
  31. int x = 0, y = 0;
  32. for(j=1;j<=k;j++)
  33. {
  34. dp[i][j] = dp[i-1][j];
  35. if(a[i]>s[j] && maxx < dp[i-1][j]) {
  36. maxx = dp[i-1][j];
  37. if(is[i-1][j])
  38. x = i-1, y = j;
  39. else {
  40. x = pre[i-1][j][0];
  41. y = pre[i-1][j][1];
  42. }
  43. }
  44. if(a[i]==s[j]) {
  45. is[i][j] = 1;
  46. dp[i][j] = maxx + 1;
  47. if(is[x][y])
  48. pre[i][j][0] = x, pre[i][j][1] = y;
  49. else {
  50. pre[i][j][0] = pre[x][y][0];
  51. pre[i][j][1] = pre[x][y][1];
  52. }
  53. continue;
  54. }
  55. if(is[i-1][j])
  56. pre[i][j][0] = i-1, pre[i][j][1] = j;
  57. else {
  58. pre[i][j][0] = pre[i-1][j][0];
  59. pre[i][j][1] = pre[i-1][j][1];
  60. }
  61. }
  62. }
  63. int ans = 0;
  64. int x = n, y = k;
  65. for(i=1;i<=k;i++)if(ans<dp[n][i]){
  66. ans = dp[n][i];
  67. x = n, y = i;
  68. }
  69. printf("%d\n",ans);
  70. if(!ans)continue;
  71. while(x+y) {
  72. if(is[x][y])G.push_back(a[x]);
  73. int x1 = pre[x][y][0];
  74. int y1 = pre[x][y][1];
  75. x = x1 , y = y1;
  76. }
  77. for(i=G.size()-1; i>=0; i--){
  78. printf("%d",G[i]);
  79. i?printf(" "):puts("");
  80. }
  81. }
  82. return 0;
  83. }
  84. /*
  85. 2
  86. 1 2
  87. 3
  88. 1 2 3
  89.  
  90. */

Codeforces 10D LCIS 找出最长公共子和产量增加这个序列 dp的更多相关文章

  1. C#中的字符串处理——找出最长数字子串

    百度测试部2015年10月份的面试题之——字符串处理,找出最长的子串. 代码如下: private static string SelectNumberFromString(string input) ...

  2. hdu 1595 find the longest of the shortest【最短路枚举删边求删除每条边后的最短路,并从这些最短路中找出最长的那条】

    find the longest of the shortest Time Limit: 1000/5000 MS (Java/Others)    Memory Limit: 32768/32768 ...

  3. 最长(大)回文串的查找(字符串中找出最长的回文串)PHP实现

    首先还是先解释一下什么是回文串:就是从左到右或者从右到左读,都是同样的字符串.比如:上海自来水来自海上,bob等等. 那么什么又是找出最长回文串呢? 例如:字符串abcdefedcfggggggfc, ...

  4. FCC JS基础算法题(3):Find the Longest Word in a String (找出最长单词)

    题目描述: 在句子中找出最长的单词,并返回它的长度.函数的返回值应该是一个数字. 基本思路,将字符串转换成数组,然后得出数组中单个元素的长度,对长度进行排序,返回最大的一个 代码: function ...

  5. javascript实现:在N个字符串中找出最长的公子串

    'use strict' module.exports = function 找出最长公子串 (...strings) { let setsOfSubstrings = [] strings.redu ...

  6. 输入n个字符串,找出最长最短字符串(若有个数相同的,都打印出来)

    首先,要求找到最长最短字符串,我们应该用数组将其存起来,输入的个数是不固定的,我们就可以用Scanner获取要输入的个数,最终找到的个数也不固定,我们可以封装两个方法,并且返回值类型为数组. 我遇到的 ...

  7. 给出两个单词(start和end)与一个字典,找出从start到end的最短转换序列

    问题 给出两个单词(start和end)与一个字典,找出从start到end的最短转换序列.规则如下: 一次只能改变一个字母 中间单词必须在字典里存在 例如: 给出 start = "hit ...

  8. 41.找出所有和为S的连续正数序列

    小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和, 他马上就写出了正确答案是100.但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数). 没多久,他就得到 ...

  9. leetcode 5 :Longest Palindromic Substring 找出最长回文子串

    题目: Given a string S, find the longest palindromic substring in S. You may assume that the maximum l ...

随机推荐

  1. JavaScript技巧&写法

    原文:JavaScript技巧&写法 JavaScript技巧篇: 1>状态机 var state = function () { this.count = 0; this.fun = ...

  2. Eclipse 发布到网站的附加产品的形式 Update Site

    Eclipse 发布到网站的附加产品的形式 Update Site 通过Update Site Project项目将自己做的插件产品公布到公网上,给客户或其它測试人员下载和应用,这样自己的插件就以网站 ...

  3. 记录这一刻:百度搜索结果“文件格式:-HTML文本”

    只要百度搜索关键词无论结果是"文件格式:-HTML文本",现在,这个问题已经被修复. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG ...

  4. react.js 从零开始(一)

    React 是什么? 网络上的解释很多...我这里把他定义为 通过javascript 的形式组件化 html的框架... React 仅仅是 VIEW 层. React 提供了模板语法以及一些函数钩 ...

  5. HTML5分析实战WebSockets一个简短的引论

    HTML5 WebSockets规范定义了API,同意web页面使用WebSockets与远程主机协议的双向通信. 介绍WebSocket接口,并限定了全双工通信信道,通过套接字网络. HTML5 W ...

  6. Skynumber

    Time Limit: 1000ms Memory Limit: 128000KB 64-bit integer IO format:      Java class name: Submit Sta ...

  7. HTML在Select具体的使用说明

    <html> <head> <SCRIPT LANGUAGE="JavaScript"> <!-- //oSelect 列表的底部加入了一 ...

  8. c++双缓冲技术,以避免闪烁绘图

    当数据量非常大时,画图可能须要几秒钟甚至更长的时间,并且有时还会出现闪烁现象,为了解决这些问题.可採用双缓冲技术来画图. 双缓冲即在内存中创建一个与屏幕画图区域一致的对象,先将图形绘制到内存中的这个对 ...

  9. iWatch # 初始化工程

    iWatch --利用swift,开发iWatch手表小应用! 远程仓库,团队开发: $ git init $ git add . $ git commit -m “ProjectName” // p ...

  10. HDU Billboard

    题目分析:给你n张海报,一个宣传板.让你在满足海报能够贴在最高位置的时候则贴的最高,无法满足时贴的最靠左,输出海报所贴的高度.假设不能贴则输出-1. 一道非常easy,可是我没想出的基础线段树. 算法 ...