我看以前写过一个最长不下降,但是感觉可能没有那么好理解emmmm

下面这个是从正序寻找的emmmm

先来一个WA代码,我给写了WA的具体行数,看看其他行其实可以看出它的思路

第二个代码是AC的

 #include <iostream>
#include <string>
#include <string.h>
#include <vector>
using namespace std;
long MAX=;
int a[];
int maxa[];
int pos[];
int main() {
int N;
cin >> N;
for (int i = ; i <= N; ++i) {
cin >> a[i];
maxa[i] = ;
}
int maxfinal=;
int final_pos=;
for (int k = ; k <= N; ++k) {
for (int i = k-; i >=; --i) {
if (a[k] > a[i]) {
maxa[k] = max(maxa[k], maxa[i] + );
pos[k]=i;//WA典范,因为maxa可能没有取maxa[i]的值,但是pos 一直在改变
if (maxa[k] > maxfinal) {
maxfinal = maxa[k];
final_pos=k;
} }
}
}
cout<<maxfinal<<endl;
for (int l = ; l < ; ++l) {
cout<<pos[l]<<endl; }
for (int j = final_pos; ; ) {
if(a[j]==)
break;
cout<<a[j]<<" ";
j=pos[j]; } }

没错就是max(,)的下一行,但是如果只需要输出长度的话就把这行给注释掉就行了

 #include <iostream>
#include <string>
#include <string.h>
#include <vector>
using namespace std;
long MAX=;
int a[];
int maxa[];
int pos[];
int main() {
int N;
cin >> N;
for (int i = ; i <= N; ++i) {
cin >> a[i];
maxa[i] = ;
}
int maxfinal=;
int final_pos=;
for (int k = ; k <= N; ++k) {
for (int i = k-; i >=; --i) {
int data;
if (a[k] > a[i]) {
if(maxa[k]<maxa[i] + ) {
maxa[k] = maxa[i] + ;
pos[k] = i;
if (maxa[k] > maxfinal) {
maxfinal = maxa[k];
final_pos = k;
}
} }
}
}
cout<<maxfinal<<endl;
for (int j = final_pos; ; ) {
if(a[j]==)
break;
cout<<a[j]<<" ";
j=pos[j]; } }

这个是输出序列的,那个存数方式还算很常用

还有就是,一维数组比二维要快?我一会儿写一篇来检测一下哈

最长不下降代码dp的更多相关文章

  1. 「10.19」最长不下降子序列(DP)·完全背包问题(spfa优化DP)·最近公共祖先(线段树+DFS序)

    我又被虐了... A. 最长不下降子序列 考场打的错解,成功调了两个半小时还是没A, 事实上和正解的思路很近了,只是没有想到直接将前$D$个及后$D$个直接提出来 确实当时思路有些紊乱,打的时候只是将 ...

  2. 最长不下降子序列//序列dp

    最长不下降子序列 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 求最长不下降子序列的长度 输入格式 第一行为n,表示n个数第二行n个数 输出格式 最长不下降 ...

  3. 算法复习——求最长不下降序列长度(dp算法)

    题目: 题目背景 161114-练习-DAY1-AHSDFZ T2 题目描述 有 N 辆列车,标记为 1,2,3,…,N.它们按照一定的次序进站,站台共有 K 个轨道,轨道遵从先进先出的原则.列车进入 ...

  4. Codeforces Round #323 (Div. 2) Once Again... CodeForces - 582B 最长非下降子序列【dp】(不明白)

    B. Once Again... time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  5. 【DP】最长不下降子序列问题(二分)

    Description 给你一个长度为n的整数序列,按从左往右的顺序选择尽量多的数字并且满足这些数字不下降. Thinking 朴素dp算法:F[i]表示到第i位为止的最长不下降子序列长度 F[i]= ...

  6. 洛谷 P2766 最长不下降子序列问【dp+最大流】

    死于开小数组的WA?! 第一问n方dp瞎搞一下就成,f[i]记录以i结尾的最长不下降子序列.记答案为mx 第二问网络流,拆点限制流量,s向所有f[i]为1的点建(s,i,1),所有f[i]为mx(i+ ...

  7. luogu2766 最长不下降子序列问题 DP 网络流

    题目大意:给定正整数序列x1,...,xn .(1)计算其最长不下降子序列的长度s.(不一定是否连续)(2)计算从给定的序列中最多可取出多少个长度为s的不下降子序列.(序列内每一个元素不可重复)(3) ...

  8. NOIP 2004 T3 合唱队形(DP、最长上升/下降子序列)

    链接:https://ac.nowcoder.com/acm/contest/1082/C来源:牛客网 题目描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队 ...

  9. dp最长不下降序列

    // // Created by snnnow on 2020/4/13. // //这是dp 问题的基础题 // //最长不下降 //(导弹拦截是其例题) //那这篇文章是讲啥呢, // 主要是吧, ...

随机推荐

  1. Java 从入门到进阶之路(二十八)

    在之前的文章我们都是通过 Java 在内存中应用,本章开始我们来看一下 Java 在系统文件(硬盘)上的操作. 系统文件就是我们电脑中的文件,简单来说就是像 Windows 系统中 C D E 等各类 ...

  2. java语言进阶(二)_Collection_泛型

    主要内容 Collection集合 迭代器 增强for 泛型 第一章 Collection集合 1.1 集合概述 在前面基础班我们已经学习过并使用过集合ArrayList ,那么集合到底是什么呢? 集 ...

  3. css3实现炫酷的文字效果_空心/立体/发光/彩色/浮雕/纹理等文字特效

    这篇文章主要整理一些css3实现的一些文字特效,分享给大家, 相信您看完会有不少的收货哦! 一.css3 空心文字 <style> .hollow{ -webkit-text-stroke ...

  4. 手把手教你玩转Git

    文章已托管到GitHub,大家可以去GitHub查看下载!并搜索关注微信公众号 码出Offer 领取各种学习资料! 微信公众号码出Offer Git应用 一.初识Git 1.1 Git的简史 同生活中 ...

  5. Pop!_OS配置JAVA环境

    Pop!_OS配置JAVA环境 #0x0 安装vscode #0x1 安装JDK #0x2 配置vscode #0x3 安装Eclipse #0x0 安装vscode 见Pop!_OS下安装C++编程 ...

  6. 数据可视化之powerBI基础(八)PowerBI的表格,你真的会用吗

    https://zhuanlan.zhihu.com/p/64413000 在PowerBI的可视化对象中,还有两个「表格」对象,表格的作用不仅可以在报表提供明细数据,还经常用来测试度量值的返回结果, ...

  7. Flask 基础组件(九):请求扩展

    #!/usr/bin/env python # -*- coding:utf-8 -*- from flask import Flask, Request, render_template app = ...

  8. Spring常见问题大全

    Spring 概述 1. 什么是spring? Spring 是个java企业级应用的开源开发框架.Spring主要用来开发Java应用,但是有些扩展是针对构建J2EE平台的web应用.Spring ...

  9. UnsupportedClassVersionError的错误处理

    造成这种错误的原因是支持Tomcat运行的JDK版本与支持application运行的JDK版本不一致导致的. 解决办法: 将JDK版本改成一致. 步骤 1.Window ——> Prefere ...

  10. nodejs之EventEmitter实现

    Node.js 所有的异步 I/O 操作在完成时都会发送一个事件到事件队列. Node.js 里面的许多对象都会分发事件:一个 net.Server 对象会在每次有新连接时触发一个事件, 一个 fs. ...