一.dp

动态规划的本质

是一种思想。通过对原问题划分成子问题,寻找子问题之间的联系,通过求解子问题得出原问题的解。与贪心不同的是,动归是深谋远虑,考虑全局最优解;而贪心则目光短浅,只考虑局部最优解。

子问题 对应 状态

子问题之间的联系 对应 状态转移

边界子问题 对应 边界状态(状态转移的边界)

边界子问题:其结果不依赖其他子问题

求解动态规划类题目的要点

定义状态

寻找状态转移方程

边界状态

值得一提的是 动态规划中边界状态是可以由状态定义轻松得出 边界不能忽略。

动态规划的分类

按照常用套路的不同,可以对动态规划进行如下分类:

一维动规

背包动规

区间动规

树形动规

DAG动规


二.搜索

搜索的重点

搜索的实现

剪枝与优化

盲目搜索与启发式搜索

盲目搜索(只是搜索的顺序不同):

深度优先搜索 宽度优先搜索

启发式搜索:

A*算法

dfs

问题

1.深度问题

2.死循环问题

解决方法

1.对深度加以限制

2.记录从初始状态到当前状态的路径

深度优先搜索的性质

一般不能保证找到最优解 当深度限制不合理时,可能找不到解,可以将算法改为可变深度限制

最坏情况时,搜索空间等同于穷举

是一个通用的与问题无关的方法

节省内存,只存储从初始节点到当前节点的路径

bfs

优先扩展深度浅的节点 通常使用一个队列来实现

广度优先搜索的性质

当问题有解时,一定能找到解

当问题为单位耗散值,且问题有解时,一定能找到最优解

方法与问题无关,

效率较低

存储量比较大

迭代加深搜索

解决宽搜内存消耗大和深搜不能保证最优解的问题

分析:

宽搜内存消耗大是由于记录了搜索扩展的节点

深搜不能保证最优解是由于其扩展不是按照代价的顺序扩展的

所以我们需要:

不记录所有扩展节点

按照顺序扩展

解决办法:

枚举最大的代价,用深搜判断是否有解

启发式搜索

在OI中常常也被称为A*搜索

关键在于对当前局面作出预估,判断当前局面到目的局面至少还需要多少步

估价函数:估价函数的好坏决定了A*算法的优劣

学大伟业 Day 2 培训总结的更多相关文章

  1. 学大伟业 Day 1 培训总结

    第一天培训,讲的基本算法,东西很多.还有些数论,图论,数据结构and some small tricks 一.输入输出技巧 //输入输出技巧 /* scanf.printf:速度快,需要记忆不同数据类 ...

  2. 学大伟业 Day 6 培训总结

    今天接着昨天的继续讲数据结构 今天先是 分块 在统计问题中,尤其是序列问题,经常涉及到区间的操作,比如修改一段区间的元素,询问某个区间的元素的信息. 如果每次都对一整个区间的每一个元素进行操作的话,那 ...

  3. 学大伟业 Day 5 培训总结

    今天讲数据结构 先从mzx大佬的ppt摘抄一段: 数据结构是计算机存储.组织数据的方式.数据结构是指相互之间存在一种或多种特定关系的数据元素的集合. 通常情况下,精心选择的数据结构可以带来更高的运行或 ...

  4. 学大伟业 Day 3 培训总结

    今天讲的字符串: 不多说,直接看题 一.表达式求值 题目大意: 输入一行一个表达式,计算其答案 表达式包含非负整数.加减乘除.括号 两种做法 ·栈 ·表达式树 这里更推荐表达式树,因为栈是先压进去,逆 ...

  5. 学大伟业 Day 4 培训总结

    今天讲的全是dp... 不多废话,先看一道经典的模板LIS(最长不下降子序列) 一.LIS 给定一个长度为N的数列,求最长上升子序列 例:1 7 2 8 3 4 答案:1 2 3 4 代码: #inc ...

  6. 学大伟业Day1解题报告

    学大伟业Day1解题报告 张炳琪 一.   时间分配 T1:30分钟  T2: 60分钟  T3:100分钟 二.答题情况及错因 T1:100         T2:55             T3 ...

  7. 学大伟业 2017 国庆 Day1

    期望得分:100+100+20=220 实际得分:100+100+20=220 (好久没有期望==实际了 ,~\(≧▽≦)/~) 对于 a........a 如果 第1个a 后面出现的第1个b~z 是 ...

  8. 2017-10-23学大伟业Day1

    T1 叉叉 题目名称 叉叉 程序文件名 cross 输入文件名 cross.in 输出文件名 cross.out 每个测试点时限 1秒 内存限制 128MB 测试点数目 10 每个测试点分值 10 是 ...

  9. 学大伟业 国庆Day2

    期望得分:30+100+0=130 实际得分:30+100+20=150 忍者钩爪 (ninja.pas/c/cpp) [问题描述] 小Q是一名酷爱钩爪的忍者,最喜欢飞檐走壁的感觉,有一天小Q发现一个 ...

随机推荐

  1. VMware虚拟网卡设置问题

    具体操作过程如下: (1)为虚拟机添加虚拟网卡 (2)添加后会自动分配子网ip,不用修改.点击应用,确定. (3)添加完成后本机的网络上会多出一个网络适配器,根据虚拟机器中的ip设置此ip地址, 这里 ...

  2. TOJ 2711 Stars

    描述 Astronomers often examine star maps where stars are represented by points on a plane and each sta ...

  3. <meta http-equiv="X-UA-Compatible" content="IE=edge" />详解

    X-UA-Compatible是针对IE8新加的一个设置,对于IE8之外的浏览器是不识别的,这个区别与content="IE=7"在无论页面是否包含<!DOCTYPE> ...

  4. Java - > for, while 及 do.while循环

    为什么要用到循环结构: 按顺序结构执行程序语句(方法或者代码块)只能被执行一次.如果要多次执行,就需要使用到循环结构(循环结构是指在程序中需要反复执行某个功能而设置的一种程序结构) 布尔表达式:是一段 ...

  5. props的异步加载问题

    在写vue项目的时候,父组件调用ajax的接口获得数据,然后赋值给data中的初始值,然后通过props传给子组件,子组件在created的时候,获得的props的值有的时候是undefined,因为 ...

  6. MySQL查询笔试综合题练习

    题目要求: 在某个数据库下建表: create table stu( -> name char(3) not null default '', -> subject varchar(10) ...

  7. c语言进制转化

    #include <stdio.h> // 进制转化 int main(void) { ; ; int i3 = 0x32C; printf( printf( printf("十 ...

  8. iPython与notebook的基本用法

    1 Ipython 安装 pip install ipython 2 Notebooke 基本用法 启动ipython使用ipython 启动notebook 使用 ipython notebook ...

  9. Recsys2018 music recomendation

    http://www.recsyschallenge.com/2018/ January 2018 Release of the "One Million Playlists" d ...

  10. 单例模式(C++)

    #include <iostream> #include <string> using namespace std; class singleton { private: si ...