INT202 例题

算法复杂度

  1. O(n):表示算法的渐进上界。如果一个算法的运行时间是O(n),那么它的运行时间最多与输入规模n成正比。换句话说,当输入规模n增加时,算法的运行时间不会超过某个常数倍的n。比如,如果一个算法的时间复杂度是O(n),那么它的运行时间可能是3n,5n,100n等。

  2. Ω(n):表示算法的渐进下界。如果一个算法的运行时间是Ω(n),那么它的运行时间至少与输入规模n成正比。换句话说,当输入规模n增加时,算法的运行时间不会比某个常数倍的n小。比如,如果一个算法的时间复杂度是Ω(n),那么它的运行时间可能是n,2n,100n等。

  3. Θ(n):表示算法的紧密界限。如果一个算法的运行时间是Θ(n),那么它的运行时间与输入规模n成正比,并且上界和下界是相同的。换句话说,当输入规模n增加时,算法的运行时间将以线性方式增长。比如,如果一个算法的时间复杂度是Θ(n),那么它的运行时间可能是3n,n,100n等,但是不会超过某个常数倍的n。

单纯判断算式

 e.g1

e.g2

e.g3

e.g4

 C, 应该是O(n^2)

e.g5

A

 一般的算法复杂度

e.g1

*

e.g2*

是这样的,用n^2进行遍历,然后n进行计算,乘起来就是n^3

e.g3

e.g4*

注意第二题,log(a)+log(b) = log(ab) 我反正忘了哈哈哈哈哈

e.g5 summation表达*

递归

e.g1*

后缀运算

主要考察的是栈

注意,减号的话是栈[-2]- 栈[-1]

 e.g1

(1)

(2)

(3)

e.g2

e.g3

二叉树

一个好用的数据可视化网站Data Structure Visualization

节点深度 O(n)

树深度O(n)

查找O(n)(二分法)

遍历 O(n)

pre order 前序:左右

in order中序:左

post order 后序:左右

e.g1根据遍历绘制树

 

Binary search tree 二叉搜索树

二叉搜索树是一种特殊的二叉树,具有以下性质:

对于每个节点 NNN:
所有左子树节点的值都小于或等于节点 N的值
所有右子树节点的值都大于节点 N的值

查找 O(logn)-O(n)

e.g1 节点能构成多少个二叉树

用这个卡塔兰公式得

. - 力扣(LeetCode)

B

0/3 =5

1/2 =2

2/1 = 2

3/0 = 5

5+2+2+5=14

 AVL tree 平衡二叉树

Height-Balance属性: 对于任何节点n, n的左右子树的高度最多相差1

All operations (search, insertion, and removal) on an AVL tree with n elements can be performed in O(log n)time

e.g1

是的,左右节点响相差不超过1

添加节点O(log n)

是在树枝的叶节点添加,再转上去

集合进阶-11数据结构(平衡二叉树旋转机制)_哔哩哔哩_bilibili

右边多了左旋,左边多了右旋

简单情况:

以左旋为例:

 1)以不平衡点节点作为支点

2)把支点左旋降级,变成左子节点,晋升原来右子节点

复杂情况:

1)以不平衡点作为支点

2)将根节点右侧往左拉

3)原先的右子节点变成新的父节点,并把多余的左子节点出让,给已经降级的根节点当右子节点

四种情况:

  • 左-左(LL)失衡:右旋。
  • 右-右(RR)失衡:左旋。
  • 左-右(LR)失衡:先左旋后右旋。
  • 右-左(RL)失衡:先右旋后左旋。

e.g1 插入节点

插入节点后检测平衡,删除节点后面的节点顶替后检查平衡

 

e.g3 构建AVL

(2,4)树

has height O(logn)

查找 O(logn)

(2,4)树(也称为2-4树或2-3-4树)是一种多路搜索树,具有以下属性:

节点大小属性:每个内部节点最多有四个子节点

深度属性:所有外部节点具有相同的深度

根据子节点的数量,(2,4)树的内部节点被称为2节点、3节点或4节点

注意,相同的元素产生的(2,4)树可能会不一样,取决于节点插入的顺序

e.g1 树高O(logn)

增O(logn)

e.g1

添加节点17

删O(logn)

e.g2增/删*

Heap 堆

【从堆的定义到优先队列、堆排序】 10分钟看懂必考的数据结构——堆_哔哩哔哩_bilibili

堆是一棵二叉树,在其内部节点上存储键,并满足以下属性:对于每个内部节点v,除了根节点key(v) ≥key(parent(v))

 •节点中的键。
•父键不大于子键。
数组表示。
•索引从1开始。
•按等级顺序获取节点。

For any given node at position i:

•    Its Left Child is at [2*i] if available.
•    Its Right Child is at [2*i+1] if available.
•    Its Parent Node is at [⌊i/2⌋] if available.

因此,堆可以用数组表示,因为堆的下标和内容是一一对应的

注意,同[2,4]树一样,同一组数可能形成不同的堆

完全二叉树?

没有左子树不能有右子树
上一层没有铺满,不能有下一层

优先队列

堆是优先级队列的一种实现,对于插入和删除都是有效的。

新的元素插入队列,弹出最小/最大元素O(logn)

可以进行排序,将队列的元素依次弹出

max heap 大根堆,min heap 小根堆

 

 e.g1

.

e.g2

C

上/下滤 O(logn)

Up-heap bubbling 上滤

上滤用于插入新元素并维护堆的性质,将新元素逐级向上移动以确保其在正确的位置。

Down-heap bubbling 下滤

下滤用于删除堆顶元素或修改堆顶元素后,重新调整堆的结构,将堆顶元素逐级向下移动以确保其在正确的位置。

注意在堆中,通常对于节点的下沉操作是有方向性的。对于最大堆(Max Heap),节点的下沉操作是沿着较大的子节点方向进行的,类似地,对于最小堆(Min Heap),节点的下沉操作是沿着较小的子节点方向进行的。

建堆

1)从叶节点插--上滤O(nlogn)

2) 先把数组中的数依次插入堆,然后再对每个父节点进行下率O(n)

(个人感觉考试的时候还是写上滤会清楚一些)

e.g1

堆排序O(nlogn)

堆顶元素弹出后用最后一个元素堆叠到堆顶,然后下滤

大根堆下滤后变成小根堆,排序完是正序

小根堆下滤后变成大根堆,排序完是倒序

Lec8 分治法 Divide and conquer

分治法_哔哩哔哩_bilibili

将一个规模为n的问题u分解为k个规模为较小的子问题,子问题相互独立且与原问题相同,递归地求解这些子问题,然后利用子问题的解合并构造出原问题的解

设计:分解(Divide);递归求解(Conquer);合并(Combine)

分析:

1.建立递归方程T(n) = aT(n/b)+f(n)

2.求解递归方程T(n)

Sort

MergeSort

QuickSort

Master Method 主定理

e.g1 case1

直接套公式

我写的

标答:

e.g2 case2

直接套公式

我写的

标答

e.g3 case3

 标答

e.g4 注意lgn有坑!*****

 标答

e.g5 同e.g4

e.g6***不符合Master method

Matrix Multiplication 矩阵乘法???(暂时搁)

Counting inversion???(暂时搁)

Lec9 最优化问题

Knapsack 背包问题

 fractional 背包

e.g1

01背包

0/1背包问题-动态规划 Knapsack_problem Dynamic Programming_哔哩哔哩_bilibili

https://alchemist-al.com/algorithms/knapsack-problem

e.g1 

C

e.g2

我做的,我习惯先按照重量排序一下再算

标答

Interval Scheduling 区间调度(暂时搁置)

动态规划——区间DP_哔哩哔哩_bilibili

 大题***

Lec10 Graph

A graph𝐺=𝑉,𝐸consists of a set of vertices (nodes) V and a set of edges E, where each 𝑒∈𝐸 is specified by a pair of vertices 𝑢,𝑣∈𝑉

一些术语

End vertices:一条边的顶点

Edges incident:一个顶点相邻的边

Adjacent vertices:相邻的顶点

Degree:是指一个顶点连接的边的数量

Path:交替的顶点和边的序列,从顶点开始,以顶点结尾,每条边的前面和后面都有它的sendpoints 

Simple Path:所有顶点和边都不相同的路径

subgraph:子图

acyclic graph: 没有 cycle的图。树是相互连接的acyclic graph

Directed acyclic graphs 有向无环图称为dag。不可能通过遍历这些边回到同一个节点。

  • 最小生成树:用于找到一个图中连接所有顶点的最小权重的树。常用的算法包括Prim算法和Kruskal算法。这些算法主要关注于连接所有顶点,而不是特定的起点和终点。

  • 最短路径:用于找到图中从一个顶点到另一个顶点的最短路径。常用的算法包括Dijkstra算法和Bellman-Ford算法。这些算法主要关注于找到从一个指定起点到一个指定终点的最短路径。

Dijkstra

记录总路径,当然是要从最短的来s

我自己做的

标答

Bellman-Ford暂时没有例题

Kruskal

从最短的边开始选逐渐选到大边

我自己做的

标答

Prim’s algorithm 找最小生成树

1.选取权值最小边的其中一个顶点作为起始点。
2.找到离当前顶点权值最小的边,并记录该顶点为已选择。
3.重复第二步,直到找到所有顶点,就找到了图的最小生成树。

e.g1

自己写的

标答

e.g2

 

e.g3

 BFS 定理证明

要是考试考这种证明我直接表演一个暴毙!

sol

Lec11 Flow 流

  • 增广路径(Augmenting Path):

    从起点s到t的简单路径,其中不能有回路
  • 剩余网络(Residual Network)

    • 剩余网络是在一个流网络中,根据当前流量情况所生成的一个新的网络。这个网络中的边表示原网络中的边上还能承载的额外流量。
    • 对于每条边,我们可以通过减去流量(已经通过的流量)来得到该边的剩余容量。如果一条边的剩余容量大于 0,则在剩余网络中存在一条对应的边,表示从该边可以继续传送流量。

 Ford-Fulkerson Algorithm

1.先找到augmenting path

2. 添加backward path

e.g1

BFS 的逐层遍历特性确保了每一层的节点在下一层的节点访问前都被访问

e.g2*

 e.g3

e.g4

 

Min-cut

13-5: 最小割 Min-Cut_哔哩哔哩_bilibili

把原有集合分割成两个部分,Min cut是让总割断的水管最小,让水无法流往终点

注意,最小割不唯一

最大流最小割问题:最大流的流量等于最小割的容量

Lec13 Modular-Arithmetic

感觉Lec13和Lec14都能看这个我们的《密码学的数学基础》到底都介绍哪些内容,难不难_哔哩哔哩_bilibili

首先有个很重要的概念 x(mod y) 这种形式表示的是x除以y得到的余数 

Euclidean algorithm

这个方法也叫辗转相除法,用来计算两个数的最大公因数

欧几里得演算法(辗转相除法)_哔哩哔哩_bilibili 这个讲的很好的

拿大数/小数直到没有余数为止

e.g1

e.g2

Extend Euclidean 拓展欧几里得/广义欧几里得

用欧几里得计算中每一步的出来的余数和商,用于计算sa +tb = gcd(a,b)中的s和t

r = a - c*b,然后通过前面的式子把a和b换掉

e.g1

e.g2

e.g3

e.g4

我做的

标答(写的好复杂噢)

Multiplicative Inverse 乘法逆元

乘法逆元在数论和抽象代数中是一个重要的概念,特别是在模运算(模算术)中有广泛应用。给定一个整数 a和一个模数 m,如果存在一个整数 x使得

a ⋅ x ≡ 1(mod m)

怎么找b在a乘法逆元:

1)先找到as + bt = 1 中的s和t(用拓展欧几里得)

所以ab互质是充要条件,充要条件哈

2)t可能得到一个负数,但是可以通过  t ≡ u(mod m)

这个u就是最终答案

e.g1

e.g2 

标答

Liner congruence

模运算的性质

 

 e.g1**

我自己写的

老师标答

e.g2**

Fast Modular Exponentiation**

从前往后加

e.g1

 彼阳的ppt写的变来变去的搞得我整了老半天,就不放老师ppt上的了,变你🐎呢推了我一个小时结果发现原来很简单

Euler's Theorem

ϕ是一个数学函数,用来计算小于等于某个正整数 n 的正整数中,与 n 互质的数的个数

这里p是质数↑

e.g1


 

e.g2 

这题是乘法逆元和欧拉定理的综合考察

sol

费马小定理********

e.g1

RSA 非对称加密

【RSA加密算法】| RSA加密过程详解 | 公钥加密| 密码学| 信息安全|_哔哩哔哩_bilibili

public modulus(公钥模数),是pq的乘积

很好的视频,使我的大脑旋转

e.g1

e=3和p=17,q=23 是公钥,求私钥d

e.g2

老师标答

e.g3 

e.g4

Lec15 P,NP

期末复习的时候看到这个老师的视频,醍醐灌顶了属于是13.1 NP问题概述_哔哩哔哩_bilibili

刘老师,你学学人家

P: P类问题是指可以在多项式时间内(即时间复杂度为多项式函数的时间内)解决的问题。

NP:NP类问题是指能够在多项式时间内验证其解的问题。即使找到一个解可能很难,但一旦有了一个解,验证其正确性可以在多项式时间内完成。因为P类问题能在多项式时间内验证所以P问题是NP问题,但是NP问题不一定是P问题

最优化问题(Optimization)转化成判定性问题

NP-complete: NP中最难的问题,所有NP都可以规约(reducibility,实例对应,输出一致,传递)到NPC问题,是NP-hard的子集

NP-hard: 多项式时间内不一定能验证

SAT

中文名叫做合取范式CNF的可满足性问题SAT,是NPC问题

3-SAT

注意,2-SAT是P问题,3-SAT是NPC

e.g1

很好我也不会证,于是请教了万能的chatgpt

标答

e.g2 3-SAT规约

这道题是把一个四合取范式规约成一个3CNF

sol

e.g3

e.g4

Yes,

公式可满足

step1. 证明是个np问题

2.可满足性

3. 一致性

e.g5

顶点问题

 Hamitonian cycle 

综合题

 e.g1

e.g2

 


e.g3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/677195.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【InternLM实战营第二期笔记】04:XTuner 微调 LLM:1.8B、多模态、Agent

文章目录 笔记微调基础知识Xtuner8G显存微调模型InternLM2 1.8B多模态实践环节数据微调过拟合WebUI 交互 多模态微调 作业 这回学乖了,打开本节课第一件事先不看教程而是装环境~ 笔记 微调基础知识 这里感慨一下,垂直领域的训练还是挺困难的,…

jenkins的简单使用

2.1.简介 Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。 2.4.Jenkins安装 1.下载安装包jenkins.war; 2.在安装…

dpdk uio整体分析及网卡加载

参考:https://zhuanlan.zhihu.com/p/477600165 一、Linux内核知识点 1. __attribute__ constructor/destructor (1)若函数被设定为constructor属性,则该函数会在 main()函数执行之前被自动的执行。 (2)若函数被设定为destructor属性,则该函数会在main()函数执…

C++类的继承与派生概念

派生和继承是自然界普遍存在的一种现象。例如,“猫”和“白猫”。当人们谈及“猫”时,知道它有4条腿,1条尾巴,抓老鼠,为哺乳动物。如谈论“白猫”时,它也是猫,只不过增加了一个新的特征,即它的毛…

Harmony开发 List/Scroll 组件最后一个item显示不全或布局显示不完整

今天在做Harmony开发的时候遇到一个问题,List组件的最后一个item显示不全,如下图,item-9显示不出来,显示了一部分 这个页面的代码结构如下: Column() {Row() {Text(文本1).fontSize(15).fontColor(Color.Black)Text(文本2).font…

论文浅尝 | THINK-ON-GRAPH:基于知识图谱的深层次且可靠的大语言模型推理方法...

笔记整理:刘佳俊,东南大学硕士,研究方向为知识图谱 链接:https://arxiv.org/pdf/2307.07697.pdf 1. 动机 本文是IDEA研究院的工作,这篇工作将知识图谱的和大语言模型推理进行了结合,在每一步图推理中利用大…

2024视频号·短视频+直播极简培训班:抓住视频号风口,流量红利

课程下载:2024视频号短视频直播极简培训班:抓住视频号风口,流量红利-课程网盘链接提取码下载.txt资源-CSDN文库 更多资源下载:关注我。 课程内容: 02 1、为什么视频号有机会,而不是抖音?(直播2024.03.0…

攻防世界---misc---can_has_stdio?

1、下载附件是一个没有后缀的文件,尝试将后缀改为txt发现里面有一些特殊字符的编码 2、查阅资料得知它是一种编程代码 3、知道了它是什么代码之后,我们就去解码(网址:El Brainfuck (copy.sh)) 4、 flag{esolangs_for_f…

Centos 7之Hadoop搭建

介绍 Hadoop Distributed File System简称 HDFS,是一个分布式文件系统。HDFS 有着高容错性(fault-tolerent)的特点,并且设计用来部署在低廉的(low-cost)硬件上。而且它提供高吞吐量(high throu…

2024年Node.js精选:50款工具库集锦,项目开发轻松上手(五)

不得不说,Node.js的强大离不开那150万个NPM包。没有NPM,Node.js依然可以使用,但绝不会如此强大。在这个系列文章中,我们探讨了每个开发者都应该了解的一些常用NPM包。在本系列的最后一篇文章中,我将介绍第41到第50个推…

QT 创建文件 Ui 不允许使用不完整类型,可以尝试添加一下任何头文件

#include "debug.h" #include "qmessagebox.h" #pragma execution_character_set("utf-8") //QT 创建文件 Ui 不允许使用不完整类型,尝试添加一下任何头文件,或者添加ui_xx.h头文件 debug::debug(QWidget *parent) : QDialog(p…

番外篇 | YOLOv5改进之结合结构重参数化网络RepVGG:极简架构,SOTA性能,让VGG式模型再次伟大!

前言:Hello大家好,我是小哥谈。ResNet、DenseNet等复杂的多分支网络可以增强模型的表征能力,使得训练效果更好,但是多分支的结构在推理的时候效率严重不足。看起来二则不可兼得。能否两全其美?RepVGG通过结构重参数化的方法,在训练的时候使用多分支结构,而在推理的时候多…

【动手学深度学习】多层感知机模型选择、欠拟合和过拟合研究详情

目录 🌊1. 研究目的 🌊2. 研究准备 🌊3. 研究内容 🌍3.1 多层感知机模型选择、⽋拟合和过拟合 🌍3.2 基础练习 🌊4. 研究体会 🌊1. 研究目的 多层感知机模型选择:比较不同多层…

2D 生存角色扮演游戏《Cryptara Conquest》即将登录 Eclipse

接下来是为狂热的游戏玩家们带来的又一个惊喜。《Cryptara Conquest》是一款以故事叙述和冒险元素作为驱动的 2D 生存 RPG 游戏,该游戏即将在 Eclipse 平台上发布。该游戏将经典老派游戏魅力与现代生存机制相结合,旨在通过怀旧、创新和区块链技术融合&am…

Linux网络编程:网络层协议|IP

前言: 网络层协议解决什么问题 当我们在上层实现了应用层协议将字符流数据转化为结构体数据,在传输层完成了通信的实现,数据的传输,但是数据最终还是得从本主机输出,从网络中进入到远端的另外一台主机。 网络层协议I…

瘦”AP与“胖”AP的区别

1. AP基本概念 无线AP,简单说就是一个无线接入点,它是无线网络的关键部分,就像是无线网络的大脑。这个无线AP啊,它跟无线路由器、无线网关、无线网桥这些设备差不多,都是干一件事儿的。它的作用就是把家里或公司里用线…

Redis 异常三连环

本文针对一种特殊情况下的Reids连环异常,分别是下面三种异常: NullPointerException: Cannot read the array length because “arg” is nullJedisDataException: ERR Protocol error: invalid bulk lengthJedisConnectionException: Unexpected end o…

续航1977公里的穿越之旅:比亚迪秦L DM-i试驾体验

5月31日,在西安这座古老而又充满活力的城市,一群自媒体驾驶着比亚迪秦L DM-i,踏上了从祖国西北到东南的穿越之旅。 在本次试驾活动中,自媒体们不仅要体验这款新能源车型的驾驶性能,而且还要亲自验证它在实际道路和极端…

基于聚类和回归分析方法探究蓝莓产量影响因素与预测模型研究

🌟欢迎来到 我的博客 —— 探索技术的无限可能! 🌟博客的简介(文章目录) 目录 背景数据说明数据来源思考 正文数据预处理数据读取数据预览数据处理 相关性分析聚类分析数据处理确定聚类数建立k均值聚类模型 多元线性回…

【专利 超音速】基于分类模型的轻量级工业图像关键点检测方法

申请号CN202311601629.7公开号(公开)CN117710683A申请日2023.11.27申请人(公开)超音速人工智能科技股份有限公司发明人(公开)张俊峰(总); 杨培文(总); 沈俊羽; 张小村 摘要 本发明涉及一种基于分类模型的…