最长不下降代码dp
我看以前写过一个最长不下降,但是感觉可能没有那么好理解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的更多相关文章
- 「10.19」最长不下降子序列(DP)·完全背包问题(spfa优化DP)·最近公共祖先(线段树+DFS序)
我又被虐了... A. 最长不下降子序列 考场打的错解,成功调了两个半小时还是没A, 事实上和正解的思路很近了,只是没有想到直接将前$D$个及后$D$个直接提出来 确实当时思路有些紊乱,打的时候只是将 ...
- 最长不下降子序列//序列dp
最长不下降子序列 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 求最长不下降子序列的长度 输入格式 第一行为n,表示n个数第二行n个数 输出格式 最长不下降 ...
- 算法复习——求最长不下降序列长度(dp算法)
题目: 题目背景 161114-练习-DAY1-AHSDFZ T2 题目描述 有 N 辆列车,标记为 1,2,3,…,N.它们按照一定的次序进站,站台共有 K 个轨道,轨道遵从先进先出的原则.列车进入 ...
- 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 ...
- 【DP】最长不下降子序列问题(二分)
Description 给你一个长度为n的整数序列,按从左往右的顺序选择尽量多的数字并且满足这些数字不下降. Thinking 朴素dp算法:F[i]表示到第i位为止的最长不下降子序列长度 F[i]= ...
- 洛谷 P2766 最长不下降子序列问【dp+最大流】
死于开小数组的WA?! 第一问n方dp瞎搞一下就成,f[i]记录以i结尾的最长不下降子序列.记答案为mx 第二问网络流,拆点限制流量,s向所有f[i]为1的点建(s,i,1),所有f[i]为mx(i+ ...
- luogu2766 最长不下降子序列问题 DP 网络流
题目大意:给定正整数序列x1,...,xn .(1)计算其最长不下降子序列的长度s.(不一定是否连续)(2)计算从给定的序列中最多可取出多少个长度为s的不下降子序列.(序列内每一个元素不可重复)(3) ...
- NOIP 2004 T3 合唱队形(DP、最长上升/下降子序列)
链接:https://ac.nowcoder.com/acm/contest/1082/C来源:牛客网 题目描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队 ...
- dp最长不下降序列
// // Created by snnnow on 2020/4/13. // //这是dp 问题的基础题 // //最长不下降 //(导弹拦截是其例题) //那这篇文章是讲啥呢, // 主要是吧, ...
随机推荐
- 第一步:安装centos_8
关于centos的安装其实大部分时候都是在虚拟机环境下安装. 好处无疑有这几个:方便,快速,主要就是整出事情了我可以直接删了重装 我这边是在vmware下进行一个安装 vmware我这边给出下载链接: ...
- Yolo车辆检测+LaneNet车道检测
Yolo车辆检测+LaneNet车道检测 源代码:https://github.com/Dalaska/Driving-Scene-Understanding/blob/master/README.m ...
- Jenkins Pipeline 部署 SpringBoot 应用
一. 安装依赖包 yum install -y wget yum install -y gcc-c++ yum install -y zlib-devel perl-ExtUtils-MakeMake ...
- 07 . Jenkins忘记root密码
重置Jenkins用户名密码 忘记用户名密码(如图)不管是忘记用户名密码还是误删jenkins目录下的users文件都可以使用下面的方式找回密码,我的版本是Jenkins 2.134 配置config ...
- 不用破解版的 Navicat 了,几款免费且好用的 SQL 客户端送给你
我是风筝,公众号「古时的风筝」. 文章会收录在 JavaNewBee 中,更有 Java 后端知识图谱,从小白到大牛要走的路都在里面. 没别的意思,今天就是为了给你推荐几款 MySQL 客户端,这几款 ...
- Pop!_OS下安装C++编程工具
Pop!_OS下C++编程 #0x0 Visual Studio Code #0x1 C++ 0x11 code::blocks #0x0 Visual Studio Code 下载安装vscode ...
- Alink漫谈(十) :线性回归实现 之 数据预处理
Alink漫谈(十) :线性回归实现 之 数据预处理 目录 Alink漫谈(十) :线性回归实现 之 数据预处理 0x00 摘要 0x01 概念 1.1 线性回归 1.2 优化模型 1.3 损失函数& ...
- window10下启动vue项目具体步骤
1. 安装nodejs 直接去nodejs官方网站下载安装包(https://nodejs.org/zh-cn/) 然后在cmd窗口里面输入 node -v 可以检测出来nodejs是否在全局环境下安 ...
- 数据可视化之powerBI技巧(十六)采悟:PowerBI作图技巧:动态显示可视化标题
默认情况下,PowerBI图表的标题是静态的,为了增强图表的可读性,通过设置动态标题,可快速展示关键信息.提升沟通效率.本文通过两个简单的例子来看看PowerBI中如何创建动态标题. /01/ 拿之前 ...
- day2:Number,tuple,str,list,set,dict
# ### Number ( int float bool complex) 1.int 整型 (正整数 0 负整数)intvar = 1print(intvar) # type 获取值的类型res ...