算法设计与分析(小总结)

2023-05-16

原先一直没注意这一门,大概是因为学这些算法的时候,板子都不知道背多少遍了。可是考试毕竟不一样,如果来个证明很容易抓瞎。

看了往年的试题,可能确实因为难度高,范围一缩再缩,虽然是基本按照算导来的,但是算法基本都是最基础的那种。20年之前网络流也是重点,最小割最大流,现在完全不提了。21年之前一般要出一道模板3SAT规约题,而本学期只是简单一提,完全没讲到具体规约的过程。

总而言之,范围还是挺有限的,不过考虑到课件全英文+大量证明,想要真掌握还是挺难。

大概有这么几个重点:

1.时间复杂度,上下界。应该会有分析题,但是我一般是靠脑补。注意理论。

五种符号分别是渐进上界O(一般的时间复杂度),上界o,渐进下界Ω,下界ω,以及一个渐进紧确界那个奇怪的符号。

可能涉及到证明,后续各种算法大概率都会出个复杂度的问吧,不过对于一般的算法看循环去猜差不多总能对。

2.递推式的复杂度解析,通常用主定理就行,偶尔可以猜猜,但是不好证明。

三种方式:猜想+数学归纳证明,递归树(也就是模拟每一层分治,分别计算,注意合并的成本),主定理(是从递归树推出来的,证明看过但是实在想不起来了。)

主定理最常用,但是有时候不好合并也需要用递归树。

 别忘了三种情况。如果前面大就取前面,一样大就加个log,后面大还需要比较af(n/b)<=cf(n)且c<1,也就是不能越分治花的时间越长,那就没法往下推了。如果满足,则用后面当上界。

logb a是怎么推出来的?考虑递归树逐层往下,一共会有logb(n)层,每层需要分裂a个子问题,那么在满足上述3的条件的情况下,可以忽略非叶子节点造成的损耗(都是log级别的),一共有a^(logb(n))个叶子,每个是O(1),总共就是O(a^logb(n)),变形成O(n^logb(a)).这是递归过程中针对每个子问题的处理的时间复杂度的上界。

但是合并子问题还有一部分成本,也就是后面的这个f(n)存在的意义。然而分割子问题的时候复杂度随着节点增加而提高,对于合并成本来说却在降低,因此有可能永远不会超过顶层的f(n).这也是在2中可以推出f(n)logn的原因,可以想象一个倒金字塔。

3.证明贪心策略,写伪代码。贪心很复杂,但是板子应该就这些,不会很难。

活动选择问题。用剪切-粘贴法证明贪心策略。

 

 证明贪心策略也就是证明贪心选的解在答案中,一般先考察某个子问题的最优解,然后试着换掉一个贪心选择,看答案是否会变小。

4.分治算法,由于快排这种玩意都没讲,分治也不会讲的很多,基本就是算算复杂度,写写思路。

5.dp,不用多说了。不知道背包问题是否需要证明,注意证明最优子结构的方法,也有可能问和贪心策略的区别,举例为啥不能贪啥的老问题。背包的话似乎讲的也不多,就是最基础的01,多重这么几种,更恶心的背包都没涉及。

钢条切割,01背包,分组背包(划掉),多重背包,可以分割的背包(不明白为啥算背包)。

当初说的最优子结构和无后效性在这里概念也有变换。

如何证明最优子结构?一般是反证,假设两个最优的子问题不在最优解里,找到矛盾之处。

 证明非常扯,差不多是我看他有他就有的意思。

无后效性——子问题不相关,我想还是前者更好理解。其实就是求解子问题不能改变别的子问题,要不然就会一直优化下去。但是课件没告诉你一些后效性可以用多维优化掉。

6.基础图论,主要是图的一些概念,dfs和bfs。注意链表,难度不会很大。强连通分支求法注意(貌似没讲Tarjan)

V是点,E是边。

图论的证明题可以试着证明一下,一般都不会。

一些概念:连通图,强连通图,子图。完全图:任意两点之间有一条边。

bfs和dfs:bfs里有一些证明题。dfs可能要模拟dfs序。

 dfs会形成一棵树,除了树上的变还会有别的边,注意分类。

强连通分量:两遍dfs找,第一次在原图上dfs,记录时间戳,第二次按照时间戳在反向图上dfs,凡是能到的都是。

7.最小生成树,我记得kruskal和prim就讲了一种,忘了是哪个,都看看好了。

事实上都讲了,为了讲kruscal专门说了并查集。

别记反了:krucal是森林,每次找最小边加入,并查集维护。

prim是一颗树,每次找连到这棵树最小的边。不用并查集,用优先队列维护。

次小生成树:只提及朴素算法,暴力拆边替换。回到OI时期或许还能搞个二分答案或者树上倍增?

瓶颈生成树:二分答案。这个难度应该就不会考了吧。

8.单源最短路,只说了Dijkstra,Bellman-ford也说了,其实就是弱化版SPFA。堆优化也没说。大概率是根据图描绘流程。

对于Bellman-ford,注意判断负权回路。课件里仍然用了近乎诡辩的方法证明。

BF需要N-1次循环,如果过了这么多循环仍然可以松弛说明有负权回路,但是实际上也许不到N-1就松弛完了,这时候就可以退出。

这就是为什么SPFA会被卡到N^2!!!!

约束图。额。

网上几乎没资料。看定义应该是源点有到所有点的权值为0的边,且其它各边之间的权值服从约束,要求找可行的解。

你赢了。

 

9.多源最短路:n次Bellman-ford,floyd-warshell。注意弗洛伊德的变体可能用来求矩阵乘法啥的(可能本来就差不多吧)

 一些复杂度。

充分可见我校算法课历史悠久。

10.NP,NP-hard,NPC以及NPC规约问题。只讲了概念,应该不会出规约题,这种难度如果不是明讲大概不太会有人能证。

稍微看看3-sat到独立集吧。

一个问题A可以约化为问题B的含义即是,可以用问题B的解法解决问题A,或者说,问题A可以“变成”问题B。也就是说B的解法能同时解决问题A和问题B,问题A可以约化为问题B。这个示例说明什么呢?A的时间复杂度是≥B的时间复杂度。这样的话,相当于我们用问题B简化了问题A。

祝考试顺利!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

算法设计与分析(小总结) 的相关文章

  • find_package()函数

    find package函数 引言1 find package用法2 find package原理3 A required library with LAPACK API not found 错误解决4 添加findpackage查询路径
  • py安装文件时报错usage: setup.py [global_opts] cmd1 [cmd1_opts] [cmd2 [cmd2_opts] ...]

    py安装文件时报错usage setup py global opts cmd1 cmd1 opts cmd2 cmd2 opts 引言solved 引言 报错 xff1a python setup py fastentrypoints u
  • VScode单步调试

    VScode配置 0 快捷键1 安装clang2 VScodeDebug3 Cmake支持gdb调试的方法 0 快捷键 稍大工程在vscode下的调试参考该博客 Ctrl 43 打开默认终端 Ctrl 43 Shift 43 新建新的终端
  • 串口通信简介

    串口通信 串口通信是一种串行异步通信 xff0c 通信双方以字符帧作为数据传输单位 xff0c 字符帧按位依次传输 xff0c 每个位占固定的时间长度 两个字符帧之间的传输时间间隔可以是任意的 xff0c 即传输完一个字符帧之后 xff0c
  • ubuntu16.0 ROS(介绍EAI的YDLIDAR-X4激光雷达在ROS下使用方法)

    YDLIDAR X4激光雷达介绍 YDLIDAR X4激光雷达是深圳越登智能科技有限公司 xff08 YDLIDAR xff0c 这家公司属于EAI xff09 研发的一款 360 度二维测距产品 xff0c 本产品基于三角测距原理 xff
  • php使用http_build_query,parse_url,parse_str创建与解析url

    1 http build query http build query 可以创建urlencode之后的请求字符串 span class hljs keyword string span http build query mixed spa
  • 无人驾驶小车调试笔记(六)-- 车轮校准

    简介 xff1a 小车的动力完全来自于两个电机带动的车轮 xff0c 在理想状态下 xff0c 给两个电机同样的驱动参数 xff0c 两个车轮会以同样的转速带动小车直线行驶 xff0c 而实际情况是每个电机可能都会有个体差异 xff0c 也
  • Nginx HTTP详解

    正文 1 Nginx启动流程 2 HTTP 初始化 新连接建立时的行为 在上次博客的最后可以看到 xff0c 在ngx event accept方法建立连接的最后一步 xff0c 将会调用ngx listening t监听结构体的handl
  • 时钟周期,机器周期,指令周期的相互关系

    1 时钟周期 61 振荡周期 xff0c 名称不同而已 xff0c 都是等于单片机晶振频率的倒数 xff0c 如常见的外接12M晶振 xff0c 那它的时钟周期 61 1 12M 2 机器周期 xff1a 8051系列单片机的机器周期 61
  • 单片机的分频是什么意思?

    分频就是单片机的时钟频率 xff08 也就是晶振的震荡频率 xff09 F经过12分频 xff0c 变换成F 12的频率 简单的来说就是以整数倍降低频率 2分频就是分频前的频率除以2 xff1b 4分频就是分频前的频率除以4 比如 xff1
  • NMOS和PMOS管

    这里我先说一下我自己分辨MOS管的方法 对于NMOS我们看下图中的箭头 xff0c 都是远离源头 对于PMOS我们看箭头 xff0c 都是指向源头 P xff1a POSITIVE积极的寻找自己的起源 N xff1a NEGTIVE消极的远
  • 基本运算放大电路

    我先说明 下面的内容应该很多人都看到过 xff0c 但是我建议还是细看 xff0c 最好自己推一下 我就是这么做的 运算放大器工作原理综述 xff1a 运算放大器组成的电路五花八门 xff0c 令人眼花瞭乱 xff0c 在分析运算放大器工作
  • PCB板框的绘制——AD19

    pcb板框的绘制当然首先要切换到keep out 层才行 找到设置 xff0c 找到keep out 假如我们要绘制一个矩形的板框 xff0c 我们选择线径就可以 手动绘制一个矩形的板框 我们需要让我们的板子边框按照我们所绘制的走线来定义
  • 零基础自学STM32-野火——GPIO复习篇——使用绝对地址操作GPIO

    今天主要是复习一下 结合野火的 零基础开发指南 名字没记住大概是这个 先放一张结构图 存储器映射 xff08 初学重点 xff09 xff1a 我们的片内外设比如 xff1a Flash Sram Fsmc 以及挂在AHB 总线上的外设 x
  • Lcd1602——斌哥51

    最新修改时间2022 7 22 LCD1602 16代表显示16个字符 xff0c 2代表总共显示两行 芯片的工作电压是4 5 5 5v 工作电流2 0ma xff08 5V xff09 模块最佳工作电压5 0v 字符尺寸 xff1a 2
  • 无人驾驶小车调试笔记(七)-- 相机校准

    简介 xff1a 在第五节的内容中 xff0c 我们学习了使用rqt工具集观看摄像头视频流的方法 xff0c 细心的同学应该会发现camera node发布的视频数据中的图像有变形现象 xff0c 图像变形会导致直线不直 xff0c 部分区
  • Python实现MySql、SqlServer增删改查操作

    span class token keyword import span pymssql span class token keyword def span span class token function connection sql
  • ds1302——斌哥51

    以下内容分别借鉴了 清翔 51 xff0c 斌哥51 xff0c 以及CSDN 普通的不普通少年 内部结构 xff1a DS1302 包括时钟 日历寄存器和 31 字节 xff08 8 位 xff09 的数据暂存寄存器 xff0c 数据通信
  • AD添加LOGO

    先上原文链接 xff1a http www allchiphome com circuit pcb logo creator http www allchiphome com circuit pcb logo creator http ww
  • 视频播放组件实战【LivePlayer H5播放器】

    在公司项目开发中 xff0c 有一个项目里面需要做一个视频播放的功能 xff0c 播放方式是调用海康平台提供的接口获取流地址来进行视频的播放并且最重要的是需要支持flash 由于前端用的Vue xff0c 对比了几个 xff0c 最后选择了

随机推荐

  • 如何用示波器测量串口

    如何确定时基 假如要测量的波特率为9600 则每一比特位的时间为 xff1a 1 9600 104 s xff0c 一般示波器横向上每个大格子里5个小格子 xff0c 要想看清一比特位一般需要一个小格子就够了 xff0c 则时基为 xff1
  • Keil使用命令行附加预定义宏编译

    1 前言 很多时候 xff0c 一份Keil工程代码可能需要满足多个不同的应用场景 可以通过逻辑判断 xff0c 将多个不同的点集成在一份代码之中 xff0c 但是嵌入式往往特别关注RAM空间 xff0c 集成过多的逻辑判断 xff0c R
  • Python的函数装饰器,@staticmethod、@classmethod 和 @property

    什么是Python 的 函数装饰器 xff1f Python 内置的 3 种函数装饰器 xff0c 分别是 xff20 staticmethod xff20 classmethod 和 64 property 那么 xff0c 函数装饰器的
  • C++11:原子交换函数compare_exchange_weak和compare_exchange_strong

    我们知道在C 43 43 11中引入了mutex和方便优雅的lock guard 但是有时候我们想要的是性能更高的无锁实现 xff0c 下面我们来讨论C 43 43 11中新增的原子操作类Atomic xff0c 我们可以利用它巧妙地实现无
  • C++11条件变量:notify_one()与notify_all()的区别

    notify one 与notify all 常用来唤醒阻塞的线程 notify one xff1a 因为只唤醒等待队列中的第一个线程 xff1b 不存在锁争用 xff0c 所以能够立即获得锁 其余的线程不会被唤醒 xff0c 需要等待再次
  • 数据库:group by 的使用

    一 概述 group by的意思是根据by对数据按照哪个字段进行分组 xff0c 或者是哪几个字段进行分组 二 语法 select 字段 from 表名 where 条件 group by 字段 或者 select 字段 from 表名 g
  • C++中 std::vector 的6种初始化方法

    1 vector lt int gt list1 默认初始化 xff0c 最常用 此时 xff0c vector为空 xff0c size为0 xff0c 表明容器中没有元素 xff0c 而且 capacity 也返回 0 xff0c 意味
  • MIMO雷达处理1

    参考文献 MIMO RADAR SIGNAL PROCESSING 以下为我自己的理解 xff0c 如有问题 xff0c 请指出 目录 初步分析虚拟阵列123 确认目标数 初步分析 MIMO radar与相控阵雷达区别在于MIMO中的各天线
  • AndroidStudio生成aar包和如何使用aar包

    我用的是android studio 2 0正式版 1 简介 aar包是Android studio下打包android工程中src res lib后生成的aar文件 xff0c aar包导入其他android studio 工程后 xff
  • C++智能指针详解:shared_ptr

    C 43 43 没有内存回收机制 xff0c 每次程序员new出来的对象需要手动delete xff0c 流程复杂时可能会漏掉delete xff0c 导致内存泄漏 于是C 43 43 引入智能指针 xff0c 可用于动态资源管理 xff0
  • C++算法题:关于树的算法

    问题1 xff1a 输入一棵二元查找树 xff0c 将该二元查找树转换成一个排序的双向链表 要求不能创建任何新的结点 xff0c 只调整指针的指向 什么是二元查找树 xff1f 比如 xff1a 转换成双向链表的顺序是 xff1a 1 3
  • C++算法题:递归和栈的算法

    问题1 xff1a 跳台阶问题 具体描述 xff0c 一个台阶总共有n级 xff0c 如果一次可以跳1级 xff0c 也可以跳2级 求总共有多少总跳法 xff0c 并分析算法的时间杂度 相当于从下往上跳 xff0c 最后剩一个 xff08
  • Linux的.service服务 实现程序开机自启

    一 service文件的位置 所有可用的单元文件存放在 lib systemd system 和 etc systemd system 目录 我们需要在 lib systemd system 下存放 service文件 xff0c 当sys
  • 计算机网络 复习提纲(完整版)

    第一章 概述 计算机网络 xff1a 利用通信线路和通信设备 xff0c 将地理位置和功能不同的多台计算机互联起来 xff0c 用完善的网络软件实现资源共享和信息传递的网络 组成 xff1a 计算机 xff0c 网络操作系统 xff0c 传
  • 无人机多任务寻径仿真软件与实验平台(一)

    项目背景 xff1a 近年来 xff0c 无人机的应用领域已经得到了极大的拓展 xff0c 旋翼无人机凭借较大的载荷 xff0c 稳定的飞行状态与对高空环境的高度适应 xff0c 成为了应用最为广泛的一类无人机 在欧洲 xff0c 北美洲等
  • 无人机实验平台(七) 实验平台的坐标转换(上)

    为什么要做坐标转换 xff1f 大疆提供的sdk中指出 xff0c 无人机通常情况下通过两个坐标系来控制方向 xff1a 自身坐标系 xff08 Body xff09 和地面坐标系 xff08 N E D xff09 这两个坐标系可以相互转
  • 无人机实验平台(十) 室内悬停问题

    VirtualStick Mode VirtualStick Mode是Sdk提供的一种底层控制模式 xff0c 通过模拟物理摇杆的运动向无人机按照一定频率发送摇杆差分信息 xff0c 使得无人机按照类似于被物理摇杆控制的方式运行 xff0
  • 第30章 ADC—电压采集—零死角玩转STM32-F429系列

    第30章 ADC 电压采集 全套 200 集视频教程和 1000 页 PDF 教程请到秉火论坛下载 xff1a www firebbs cn 野火视频教程优酷观看网址 xff1a http i youku com firege 本章参考资料
  • 大数据安全考试提纲

    范围划得虽大 xff0c 但是主题不多 xff0c 和往常一样记录一下重点 考试范围 1 大数据安全概念及目标 2 传统访问控制技术和基于密码的访问控制技术 3 角色挖掘的算法 4 对称密码 xff0c 非对称密码 xff0c hash算法
  • 算法设计与分析(小总结)

    原先一直没注意这一门 xff0c 大概是因为学这些算法的时候 xff0c 板子都不知道背多少遍了 可是考试毕竟不一样 xff0c 如果来个证明很容易抓瞎 看了往年的试题 xff0c 可能确实因为难度高 xff0c 范围一缩再缩 xff0c