找到 210 篇文章 关于算法分析

数据结构中的邻接表

Arnab Chakraborty
更新于 2019年8月27日 13:45:56

4K+ 次浏览

图是一种非线性数据结构。它使用节点表示数据,并使用边表示它们之间的关系。一个图 G 包含两个部分:顶点和边。顶点用集合 V 表示,边用集合 E 表示。所以图的表示法是 G(V, E)。让我们来看一个例子来了解一下。在这个图中,有五个顶点和五条边。这些边是有向的。例如,如果我们选择连接顶点 B 和 D 的边,则源顶点是 B,目标顶点是 D。所以我们可以从 B 移动到 D,但不能从… 阅读更多

数据结构中排序方法的比较

Arnab Chakraborty
更新于 2019年8月27日 13:43:07

6K+ 次浏览

在这里我们将看到一些排序方法。有 200 多种排序技术。我们将看到其中几种。一些排序技术是基于比较的排序,一些是非基于比较的排序技术。基于比较的排序技术包括冒泡排序、选择排序、插入排序、归并排序、快速排序、堆排序等。这些技术被认为是基于比较的排序,因为在这些技术中,值被比较,并在不同阶段被放置到排序位置。在这里我们将看到这些技术的时空复杂度。分析类型冒泡排序选择排序插入排序归并排序快速排序堆排序最佳情况O(n2)O(n2)O(n)O(log n)O(log n)O(logn)平均情况O(n2)O(n2)O(n2)O(log n)O(log n)O(log n)最坏情况O(n2)O(n2)O(n2)O(log n)O(n2)O(log n)一些排序算法是… 阅读更多

数据结构中搜索方法的比较

Arnab Chakraborty
更新于 2019年8月27日 13:39:01

5K+ 次浏览

在不同的情况下,我们执行不同的搜索方案来查找一些键。在本节中,我们将看到两种搜索技术,顺序搜索和二分搜索,它们之间有什么基本区别。顺序搜索二分搜索时间复杂度为 O(n)时间复杂度为 O(log n)在常数时间内查找位于第一个位置的键在常数时间内查找位于中间位置的键容器中元素的顺序不会影响。容器中的元素必须排序数组和链表可以用来实现它它不能直接在链表中实现。我们需要改变基本的规则… 阅读更多

数据结构中的栈 ADT

Arnab Chakraborty
更新于 2019年8月27日 13:36:02

22K+ 次浏览

抽象数据类型是一种特殊的数据类型,其行为由一组值和一组操作定义。“抽象”关键字的使用是因为我们可以使用这些数据类型,我们可以执行不同的操作。但是这些操作是如何工作的,对用户来说是完全隐藏的。ADT 是由基本数据类型构成的,但操作逻辑是隐藏的。在这里我们将看到栈 ADT。这些是栈 ADT 的一些操作或函数。isFull(),用于检查栈是否已满isEmpty(),用于检查栈是否为空… 阅读更多

数据结构中的凸包示例

Arnab Chakraborty
更新于 2019年8月27日 13:34:33

2K+ 次浏览

在这里我们将看到一个关于凸包的例子。假设我们有一组点。我们必须通过取较少的点来做一个多边形,这将覆盖所有给定的点。在本节中,我们将看到 Jarvis March 算法来获得凸包。Jarvis March 算法用于从给定的一组数据点中检测凸包的角点。从数据集的最左点开始,我们通过逆时针旋转将点保持在凸包中。从当前点,我们可以通过检查… 阅读更多

数据结构中的最优二叉搜索树

Arnab Chakraborty
更新于 2019年8月27日 13:03:53

1K+ 次浏览

一组整数按排序顺序给出,另一个数组 freq 为频率计数。我们的任务是创建一个具有这些数据的二叉搜索树,以找到所有搜索的最小成本。创建一个辅助数组 cost[n, n] 来解决和存储子问题的解决方案。成本矩阵将保存数据,以便自底向上地解决问题。输入- 节点作为键值和频率。键 = {10, 12, 20} 频率 = {34, 8, 50}输出- 最小成本为 142。这些是从给定值中可能得到的 BST。对于情况 1,成本… 阅读更多

数据结构中的负二项分布

Arnab Chakraborty
更新于 2019年8月27日 12:54:07

103 次浏览

负二项分布是一种随机数分布,它将根据负二项离散分布产生整数。这被称为帕斯卡分布,因此负二项分布可以写成$$P\lgroup i\arrowvert k,p\rgroup=\lgroup \frac{k+i-1}{i}\rgroup p^{k}\lgroup 1-p\rgroup^{i}$$示例 在线演示#include #include using namespace std; int main(){    const int nrolls = 10000; // 掷骰子的次数    const int nstars = 100; // 分布的最大星数    default_random_engine generator;    negative_binomial_distribution distribution(3,0.5);    int p[10]={};    for (int i=0; i

数据结构中的几何分布

Arnab Chakraborty
更新于 2019年8月27日 12:50:58

309 次浏览

几何分布是对于 n = 0, 1, 2, … 的离散概率分布,具有概率密度函数$$P\lgroup n\rgroup=p\lgroup1-p\rgroup^{n}$$分布函数为−$$D\lgroup n\rgroup=\displaystyle\sum\limits_{i=0}^n P\lgroup i \rgroup=1-q^{n+1}$$示例 在线演示#include #include using namespace std; int main(){    const int nrolls = 10000; // 掷骰子的次数    const int nstars = 100; // 分布的最大星数    default_random_engine generator;    geometric_distribution distribution(0.3);    int p[10]={};    for (int i=0; i

数据结构中的二项分布

Arnab Chakraborty
更新于 2019年8月27日 12:41:00

335 次浏览

二项分布是获得 N 次伯努利试验中 n 次成功的离散概率分布 Pp(n | N)(具有由 x = 0 和 x = 1 标记的两个可能的结果。x = 1 为成功,x = 0 为失败。成功发生的概率为 p,失败发生的概率为 q,q = 1 – p。)因此二项分布可以写成$$P_{p}\lgroup n\:\arrowvert\ N\rgroup=\left(\begin{array}{c}N\ n\end{array}\right) p^{n}\lgroup1-p\rgroup^{N-n}$$示例 在线演示#include #include using namespace std; int main(){    const int nrolls = 10000; // 掷骰子的次数    const int nstars = 100; // … 阅读更多

数据结构中的最小生成树

Arnab Chakraborty
更新于 2019年8月27日 12:29:59

16K+ 次浏览

生成树是无向图的子集,它通过最少的边连接所有顶点。如果图中的所有顶点都连接在一起,则至少存在一个生成树。在一个图中,可能存在多个生成树。最小生成树最小生成树 (MST) 是连接加权无向图的所有顶点的边的子集,其总边权重最小。为了导出 MST,可以使用 Prim 算法或 Kruskal 算法。因此,我们将在这章讨论 Prim 算法。正如… 阅读更多

广告