---恢复内容开始---

今天全是DP

awsl,真的好难

先从斐波那契开始:

dp:满足有一个状态边界条件(f[0]=0,f[1]=1)

边界条件:不需要计算其他状态的值而可以直接得出的状态或者最底层状态(不能由其他状态推出来)

然后是状态转移方程:f[n]=f[n-1]+f[n-2](然后是矩阵加速或者递推。。)

总之:边界条件,状态,转移方程为三大核心(其他都是一些题目变量。)

据说动态规划和dag(大哥)是等价的,但是图论后几天再讲。。QWQ

DP有这几种:(zhx大佬的神仙字体)

这是斐波那契数列顺推:

用别人更新自己。

逆推:

用自己更新别人。

记忆化搜索:

复杂度O(f[n])f[n]为第n项的值

其实他有通项公式的:

也就是说,复杂度为指数级别,因为右边那一项小于1,他的n次方也小于一

为何如此之慢?

因为他有重复调用(f[n]=f[n-1]+f[n-2],f[n-1]=f[n-2]+f[n-3])f[n-2]被调用两次

那么我们再开一个数组,用来判断f[n]是否被算过(suan_le_mei数组)

算过就是1,否则为0(bool)

也就是判断是否被算过(f[n]已经有值了),算过就直接返回,没算过就1.算2.赋值bool3.赋值f[n]

没错就是这样QWQ(%zhx大佬竟然把蒟蒻讲明白了)

在安利一下本人写的斐波那契矩阵加速:https://www.cnblogs.com/lbssxz/p/10679655.html

例题完结

常见dp种类:

其他dp好可怕(最可怕的是未知)

还有两种NOIP涉及概率比较小的:

但是其他4种dp套路要背熟。

1,数位dp:

给定两个正整数l,r,求l到r有多少个数?

(wtf这个题不是r-l+1吗)

但是,zhx让你用数位dp做。

首先将题目转化一下(减去l)得0到x有多少个数这个问题

那么设0<=v<=x,将v按十进制位数分解,得每一位vn,vn-1,vn-2....v1,我们从高位开始填v的位数,要分两种情况:

1,当前面已经填好的位数和x对应位数相同时,现在填的位数必须小于等于x对应位数才满足v<=x

2,当前面有至少一位和x对应位数不相同时,这意味着当前一位不管填多少,都满足v<x,那么,0到9随便填就行,

状态:设数组f[i][j],代表当前填到了第i位,j的值为(0:当前面几位有至少一位不和x对应位相等时,随便填  1:当前面几位都相同时只能填vi<=x[i])

状态转移:从第一位开始,if分两种情况递归

代码:先存x的位数:

其中z为存x位数的数组(下标从0开始)

然后是dp主体部分:

首先必须清空memset()%

初始化:why?因为他们在n+1位的值都为0,所以相等的情况只有一种

然后用一个for循环,枚举从第n位到第0位,然后分情况转移就ok了。QWQ

改一下问题:求l,r区间内有多少个相邻数位只差大于2的数?

状态为了包含所有条件,发生了变化

其他改改就行。

2.树形dp

给你一个有n个结点的树,求它有几个点(没错答案就是n你没看错

老师竟然把这么简单的题让我们用树形dp做

又变难了

#include<iostream>

using namespace std;

int f[];

void dfs(int p)
{
for (x is p's son)
{
dfs(x);
f[p] += f[x];
}
f[p] ++;
} int main()
{
cin >> n;
read_tree(); dfs();
cout << f[] << endl; return ;
}

状态dp

状压复杂度为

而n<=20时为状压的数据范围,考虑使用状压

清北学堂清华大学钟皓曦神仙讲课day3摘要的更多相关文章

  1. 清北学堂北京大学吴耀轩神仙讲课day5摘要

    今天讲图论 图是啥?(白纸上的符号?) 对于一个拥有n个顶点的无向连通图,它的边数一定多于n-1条.若从中选择n-1条边,使得无向图仍然连通,则由n个顶点及这 n-1条边(弧)组成的图被称为原无向图的 ...

  2. 清北学堂 2020 国庆J2考前综合强化 Day3

    目录 1. 题目 T1 石头剪刀布 题目描述 Sol T2 铺地毯 题目描述 Sol T3 数列游戏 题目描述 Sol T4 数星星 题目描述 Sol 2. 算法 -- 动态规划 1. 概述 2. 线 ...

  3. 清北学堂学习总结day2

    今天是钟皓曦大佬讲课,先来膜一波   %%%%% •数论 数论是这次培训的一个重点,那么什么是数论呢? 数论是研究整数性质的东西,所以理论上day2不会涉及小数QwQ (切入正题) •整除性: 设a, ...

  4. 清北学堂2017NOIP冬令营入学测试P4745 B’s problem(b)

    清北学堂2017NOIP冬令营入学测试 P4745 B's problem(b) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试 描述 题目描 ...

  5. 清北学堂2017NOIP冬令营入学测试 P4744 A’s problem(a)

    清北学堂2017NOIP冬令营入学测试 P4744 A's problem(a) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试题,每三天结算 ...

  6. 济南清北学堂游记 Day 1.

    快住手!这根本不是暴力! 刷了一整天的题就是了..上午三道题的画风还算挺正常,估计是第一天,给点水题做做算了.. rqy大佬AK了上午的比赛! 当时我t2暴力写挂,还以为需要用啥奇怪的算法,后来发现, ...

  7. 清明培训 清北学堂 DAY2

    今天是钟皓曦老师的讲授~~ 总结了一下今天的内容: 数论!!! 1.整除性 2.质数 定义: 性质:  3.整数分解定理——算数基本定理 证明: 存在性: 设N是最小不满足唯一分解定理的整数 (1)  ...

  8. 清明培训 清北学堂 DAY1

    今天是李昊老师的讲授~~ 总结了一下今天的内容: 1.高精度算法 (1)   高精度加法 思路:模拟竖式运算 注意:进位 优化:压位 程序代码: #include<iostream>#in ...

  9. 五一培训 清北学堂 DAY3

    今天是钟皓曦老师的讲授~ 今天的内容:动态规划 1.动态规划 动态规划很难总结出一套规律 例子:斐波那契数列  0,1,1,2,3,5,8,…… F[0]=0 F[1]=1 F[[n]=f[n-1]+ ...

随机推荐

  1. 关系代数(Relation Algebra)与SQL语句的对应关系

    SQL语句的执行一般是先翻译为关系代数再被执行的(能有效提高执行速度),所以我们有必要 了解关系代数与SQL语句间的对应关系. 就像高中代数由+-*/和数字组成,关系代数是由union.interse ...

  2. Spring----EJB

    EJB 是 Java EE 诸多规范之一,而 Spring 仅仅是一个框架并不是 Java EE. EJB 是百分百纯血统的 JCP 官方规范,而 Spring 是民间发起的框架. EJB 必须运行在 ...

  3. C++中sort函数使用方法

    一.sort函数 1.sort函数包含在头文件为#include<algorithm>的c++标准库中,调用标准库里的排序方法可以实现对数据的排序,但是sort函数是如何实现的,我们不用考 ...

  4. 【Deep Learning Nanodegree Foundation笔记】第 0 课:课程计划

    第一周 机器学习的类型,以及何时使用机器学习 我们将首先简单介绍线性回归和机器学习.这将让你熟悉这些领域的常用术语,你需要了解的技术进展,并了解深度学习在更大的机器学习背景中的位置. 直播:线性回归 ...

  5. Java基础/网络经验

    一.Java新特性好文--掘金 1.Java8 新特性指导手册 2.Java 11 已发布,String 还能这样玩 二.Java避坑 1.为什么阿里巴巴不建议在for循环中使用"+&quo ...

  6. 深入理解java:3. NIO 编程

    I/O简介 I/O即输入输出,是计算机与外界世界的一个借口. IO操作的实际主题是操作系统. 在Java编程中,一般使用流的方式来处理IO,所有的IO都被视作是单个字节的移动,通过stream对象一次 ...

  7. 虚拟机 编辑器 vi使用方法详细介绍

    vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令.由于对Unix及Linux系统的任何版本,vi编辑器是完全相 ...

  8. CDH6.2中capacity队列的分配

    配置: yarn.scheduler.capacity.root.queues

  9. CDH6.2扩容

    参考: yum方式扩容: https://www.cnblogs.com/yinzhengjie/articles/11104776.html 二进制包方式扩容: https://www.cnblog ...

  10. [转帖]Linux下批量替换文件内容方法

    Linux下批量替换文件内容方法 https://www.cnblogs.com/fjping0606/p/4428850.html 刚才用到的命令 原作者写的挺好的记录一下 以后 用. 1:查找fi ...