qbxt Day2 on 19-7-25
qbxt Day2 on 19-7-25
——TGZCBY
上午
1. 矩阵乘法在图论上的应用
有的时候图论的转移方程可以用dp的方式转移
特别是两个数的乘积求和的时候
比如邻接矩阵中f[i][j]表示走了i条边之后到达j点的方案数
直接用最后的矩阵*邻接矩阵^p就基本OK
通常情况下能够用矩阵乘法解决的优化问题
都有这种情况出现
然而要注意:数据范围
因为矩阵乘法的复杂度几乎无法保证\(\leq O(n^2)\)
我们这时候还是需要尽量去合并范围更小的乘法项
去优化这个更加难受的优化
牢记矩阵乘法有结合律,没有交换律
2. 搜索的剪枝技巧
zhx:说实话,我无法教给你们万用的技巧
因为每一个题都有一个特定的剪枝技巧
真的!!每一个题都不一样的
但是一些通用的剪枝技巧还是有迹可循
比如我们先想:什么时候用bfs
bfs通常使用在计数的时候
这个时候我们不会让dfs去跑一遍作死
然后还有前后数据没有太大关联的时候
这个时候状态转移好转移啊
如果bfs炸了,我们还是回到一个dfs上
dfs的好处就是状态转移直观啊
但是dfs无法满足大量的转移
怎么办呢?
这里提供几个解决办法:
改变枚举顺序
通常出题人是不会让你过正常思维整出来的题目的
所以我们要换一种顺序去得到正确答案并且快速枚举
可行性剪枝
说白了就是往最好的方面去走,然后排除绝对不可能的选项
先走最有可能的选项
这样我们就有了一个更好的搜索树让可行性这个剪枝更加优秀
判重
有一些搜索的搜索树是相同的
可能 or 不可能都剪掉
然后有一部分填空的题目上下、左右有对称性
如果重复也可以直接剪掉
卡时
有的时候你已经算出正确的答案了
特别是你的枚举顺序特别好的时候
这个时候如果快要超时了(当然你不知道答案是否正确)
你就赶紧掐断这个搜索树
直接输出目前为止最好的答案
这也不失为一种暴力的好办法
毕竟有的时候确实是好用(Orz)
搜索就说这么多
下午
基础数据结构
- 单调栈
单调栈当然是比较高级的栈
其中的元素满足一定的单调性
当我们弹出其中元素的时候
我们还要进行状态的转移
- BST
二叉搜索树之所以还讲
是因为要为后面线段树做好铺垫
而且搜索树的性质、思想十分重要
所以讲了BST
- 树状数组
树状数组之所以还有用处
是因为代码短,常数小
而且用它的地方还有求逆序对
所以好处多多
但是局限性很大
只要元素不满足“可以相减来转移”的性质
树状数组就废了
- 线段树
线段树是一个好东西
在维护区间操作的时候十分的给力
注意tag的用法
有的时候还是要进行一波玄学操作的
- 左偏树
老师竟然不会普通堆!于是一波福利就来了。
这个左偏树我做了详细的介绍,可以 点这里 来查看。
今天的例题我先不放了......等我先都做完了再说qwq
qbxt Day2 on 19-7-25的更多相关文章
- QBXT Day2主要是数据结构(没写完先占坑)
简单数据结构 本节课可能用到的一些复杂度: O(log n). 1/1+1/1/.....1/N+O(n log n) 在我们初学OI的时候,总会遇到这么一道题. 给出N次操作,每次加入一个数,或者询 ...
- 19.3.25 sql查询语句
1.单表查询:select * from 表名 where id = 111 2.查询表内数据并以id排序:select * from 表名 order by id (降序:desc/升序:asc) ...
- QBXT Day2
遭遇[问题描述]你是能看到第一题的 friends呢.—— hjaN座楼房,立于城中 .第i座楼,高度 hi.你需要一开始选择座楼,开始跳楼. 在第 i座楼准备跳需要 ci的花费. 每次可以跳到任何一 ...
- Java每日一面(Part1:计算机网络)[19/11/25]
作者:晨钟暮鼓c个人微信公众号:程序猿的月光宝盒 1. HTTP相关[2] 1.1Get请求和Post请求的区别 从三个层面来回答: 1.1.1 从HTTP报文层面: Get请求将请求信息放在UR ...
- 蓝桥杯刷题,第四界省赛B组
题头,本内容的题目和部分内容均来自博客:https://blog.csdn.net/ryo_218/article/details/79704030 ,在此感谢. 1. 题目标题:高斯日记大数学家高斯 ...
- 【转载】JAVA基础:注解
原文:https://www.cnblogs.com/xdp-gacl/p/3622275.html#undefined 一.认识注解 注解(Annotation)很重要,未来的开发模式都是基于注解的 ...
- java基础—注解annotation
一.认识注解 注解(Annotation)很重要,未来的开发模式都是基于注解的,JPA是基于注解的,Spring2.5以上都是基于注解的,Hibernate3.x以后也是基于注解的,现在的Struts ...
- 【Java】时间戳与Date相互转换
时间戳转Date public static void main(String[] args) { // 10位的秒级别的时间戳 long time1 = 1527767665; String res ...
- @interface 注解详解
转:http://www.cnblogs.com/xdp-gacl/p/3622275.html 只为成功找方法,不为失败找借口! Java基础加强总结(一)——注解(Annotation) 一.认识 ...
随机推荐
- linux点滴记录
以下均为在Ubuntu下实践操作 更改DNS //编辑文件 - “/etc/resolv.conf”,打开“终端应用程序”-“附件” - “终端”,在终端里输入下面的命令: sudo nano /et ...
- ruby基本语法(2)
关于数组 Ruby数组中的数据类型可以不相同并且长度也是可变的.(好聪明啊感觉用的久了就会变笨了,除非你本来就是老手)比如下面的例子 Myarray=[1,2,“ruby”] Ruby也支持那种-1的 ...
- VulnStack靶场实战(未完成)
环境搭建 https://www.cnblogs.com/HKCZ/p/11760213.html 信息收集 目录爆破 这里发现有phpmyadmin目录,这里可以直接获取webshell 参照: h ...
- CSS实现背景图片屏幕自适应
在做登陆页面等的首页的时候,经常会遇到需要放一张背景大图的情况,并且需要图片按比例缩放,来适应不同屏幕的大小. html代码如下: <!DOCTYPE html> <html lan ...
- Java-多线程第三篇3种创建的线程方式、线程的生命周期、线程控制、线程同步、线程通信
1.Java使用Thread类代表线程. 所有的线程对象必须是Thread类或其子类的实例. 当线程继承Thread类时,直接使用this即可获取当前线程,Thread对象的getName() ...
- [已解决]报错: Windows下Redis服务无法启动,错误 1067 进程意外终止解决方案
启动redis时出现的报错内容: 解决方法: 找到登录状态 如果是网络服务,直接双击此服务,修改为本地系统服务即可启动!
- JavaScript面向对象编程(1)-- 基础
自从有了Ajax这个概念,JavaScript作为Ajax的利器,其作用一路飙升.JavaScript最基本的使用,以及语法.浏览器对象等等东东在这里就不累赘了.把主要篇幅放在如何实现JavaScri ...
- 关于GeneXus中的ForeachCommand命令
首先作为我们开发过程中必不可少的命令For Each 有着无与伦比的重要性 但是我们从Wiki上得知 我们用到的可能只是它一丢丢的能力并没有全部使用出来. 所以 这篇文档将记 ...
- VPX板卡 基于XC7K325T的3U VPX FMC接口数据收发预处理平台
一.板卡概述 标准VPX 3U板卡, 基于Xilinx公司的FPGAXC7K325T-2FFG900 芯片,pin_to_pin兼容FPGAXC7K410T-2FFG900 ,支持PCIe ...
- GC(垃圾回收器)中的算法
GC的两种判定方法 (1) 引用计数法 给对象添加一个引用计数器,每当引用一次+1,每次失效时-1,当计数器为0时,表示对象就是不可能再被使用的. (2) 可达性分析算法 将“GC Roots”对象作 ...