学大伟业 Day 4 培训总结
今天讲的全是dp...
不多废话,先看一道经典的模板LIS(最长不下降子序列)
一.LIS
给定一个长度为N的数列,求最长上升子序列
例:1 7 2 8 3 4
答案:1 2 3 4
代码:
#include <bits/stdc++.h>//突然想用万能库 using namespace std; const int maxn = ;
int n, data[maxn], dp[maxn], from[maxn];//方案
void output(int x)
{
if(!x) return ;
output(from[x]);
cout<<data[x]<<" ";
}
int main()
{
cin>>n;
for(int i = ; i <= n;i++) cin>>data[i]; for(int i = ; i <= n;i++)
{
dp[i] = ;
from[i] = ;
for(int j = ; j < i; j++)
{
if(data[j] < data[i]&&dp[j]+ > dp[i])
{
dp[i] = dp[j] + ;
from[i] = j;
}
}
} int ans = dp[], pos = ;
for(int i = ; i <= n; i++)
if(ans < dp[i])
{
ans = dp[i];
pos = i;
}
cout<<ans<<endl;
output(pos);
return ;
}
二.背包问题
背包就不多讲了,背包九讲里面非常明白了,也是很基础的dp
N个物品,每个物品有价值和体积两个属性
从中选出若干个物品,体积和不超过V 要求选出的物品价值和最大
每个物品只能选一次(01背包)
体积可能是多维(多维背包)
物品可以被选的次数可能是有限次或者无限次(完全背包)
物品之间可能存在依赖(依赖背包)
......
三.ST表
思想:倍增、DP(状态转移方程: F[i,j] = min/max (F[i,j - 1],F[i + 2^(j - 1),j - 1]) )
功能:求任意区间的最大值
要求:静态的,无法修改数据
空间复杂度:O(nlogn)
时间复杂度:O(nlogn) – O(1)
#include <cstdio>
#include <algorithm>
using namespace std;
int const maxn = ;
int st[maxn][], a[maxn], ans[maxn];
int n, m, left, right, j, i;
int main()
{
scanf("%d%d", &n, &m);
for(i = ; i <= n; i++)
{
scanf("%d", &a[i]);
st[i][] = a[i];
} for(j = ; (<<j) <= n; j++)
for(i = ; i <= n-(<<j) + ; i++)
st[i][j] = min(st[i][j-] , st[i+( <<(j-) )][j-]); for(i = ; i <= m; i++)
{
scanf("%d%d", &left, &right);
j = ;
while((<<(j+)) <= (right-left+)) j++;
ans[i] = min(st[left][j],st[right-(<<j)+][j]);
} for(i = ; i <= m; i++)
printf("%d ",ans[i]);
return ;
}
还有一部分...待我再细细思考总结...(说白了就是现在还不太明白)
学大伟业 Day 4 培训总结的更多相关文章
- 学大伟业 Day 1 培训总结
第一天培训,讲的基本算法,东西很多.还有些数论,图论,数据结构and some small tricks 一.输入输出技巧 //输入输出技巧 /* scanf.printf:速度快,需要记忆不同数据类 ...
- 学大伟业 Day 6 培训总结
今天接着昨天的继续讲数据结构 今天先是 分块 在统计问题中,尤其是序列问题,经常涉及到区间的操作,比如修改一段区间的元素,询问某个区间的元素的信息. 如果每次都对一整个区间的每一个元素进行操作的话,那 ...
- 学大伟业 Day 5 培训总结
今天讲数据结构 先从mzx大佬的ppt摘抄一段: 数据结构是计算机存储.组织数据的方式.数据结构是指相互之间存在一种或多种特定关系的数据元素的集合. 通常情况下,精心选择的数据结构可以带来更高的运行或 ...
- 学大伟业 Day 3 培训总结
今天讲的字符串: 不多说,直接看题 一.表达式求值 题目大意: 输入一行一个表达式,计算其答案 表达式包含非负整数.加减乘除.括号 两种做法 ·栈 ·表达式树 这里更推荐表达式树,因为栈是先压进去,逆 ...
- 学大伟业 Day 2 培训总结
一.dp 动态规划的本质 是一种思想.通过对原问题划分成子问题,寻找子问题之间的联系,通过求解子问题得出原问题的解.与贪心不同的是,动归是深谋远虑,考虑全局最优解:而贪心则目光短浅,只考虑局部最优解. ...
- 学大伟业Day1解题报告
学大伟业Day1解题报告 张炳琪 一. 时间分配 T1:30分钟 T2: 60分钟 T3:100分钟 二.答题情况及错因 T1:100 T2:55 T3 ...
- 学大伟业 2017 国庆 Day1
期望得分:100+100+20=220 实际得分:100+100+20=220 (好久没有期望==实际了 ,~\(≧▽≦)/~) 对于 a........a 如果 第1个a 后面出现的第1个b~z 是 ...
- 2017-10-23学大伟业Day1
T1 叉叉 题目名称 叉叉 程序文件名 cross 输入文件名 cross.in 输出文件名 cross.out 每个测试点时限 1秒 内存限制 128MB 测试点数目 10 每个测试点分值 10 是 ...
- 学大伟业 国庆Day2
期望得分:30+100+0=130 实际得分:30+100+20=150 忍者钩爪 (ninja.pas/c/cpp) [问题描述] 小Q是一名酷爱钩爪的忍者,最喜欢飞檐走壁的感觉,有一天小Q发现一个 ...
随机推荐
- 深入理解JavaScript系列(8):S.O.L.I.D五大原则之里氏替换原则LSP
前言 本章我们要讲解的是S.O.L.I.D五大原则JavaScript语言实现的第3篇,里氏替换原则LSP(The Liskov Substitution Principle ). 英文原文:http ...
- Hashtable 键值对集合
// Hashtable 键值对集合 一个键对应一个值 Hashtable ht=new Hashtable(); ht.Add(,"张三"); ht.Add(,'男'); ht ...
- Google android开发者 中国官方文档开放了呀
Google官方开发文档地址 包括 android , android TV
- 关于C#的Lock锁思考
大家都知道多线程并发时候存在一个线程同步的问题,一般使用lock关键字来处理. lock关键字的结果如下: object locker=new object(); lock(locker) { ... ...
- 快速排序——Java实现
一.排序思想 快速排序是由冒泡排序改进而得到的,是一种分区交换排序方法.思想如下:一趟快速排序采用从两头向中间扫描的方法,同时交换与基准记录逆序的记录. 在待排序的N个记录中任取一个元素(通常取第一个 ...
- C++里创建 Trie字典树(中文词典)(一)(插入、遍历)
萌新做词典第一篇,做得不好,还请指正,谢谢大佬! 写了一个词典,用到了Trie字典树. 写这个词典的目的,一个是为了压缩一些数据,另一个是为了尝试搜索提示,就像在谷歌搜索的时候,打出某个关键字,会提示 ...
- js异步流程控制-回调
f1为耗时操作,f2依赖f1的数据,因此f2必须在f1之后执行: 个人理解是:将f2(回调函数)的代码放在异步函数内部的最后执行,相当于把同步操作的代码融合到异步函数内部的最后: let tag = ...
- SQLAlchemy的使用---外键ForeignKey数据库创建与连接
# 一对多建表操作 from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() from sql ...
- BZOJ4010: [HNOI2015]菜肴制作(拓扑排序 贪心)
题意 题目链接 Sol 震惊,HNOI竟出NOI原题 直接在反图上贪心一下. // luogu-judger-enable-o2 // luogu-judger-enable-o2 #include& ...
- iOS开发之Objective-c的AES128加密和解密算法的实现
#import <Foundation/Foundation.h> #import <CommonCrypto/CommonDigest.h> #import <Comm ...