- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试解决以下算法的时间复杂度:
s = 0;
i = 1;
while (s < n) {
s = s + i;
i = i + 1;
}
但是,我无法确定 while 循环中对数底数的幂。
我知道对于 n=5
它会在 while 循环中迭代 3 次,对于 n=50
会迭代 10 次,但是你如何从中确定大哦?
最佳答案
时间复杂度为O(Sqrt(2n))
.
让我们假设 s=s+i
和 i=i+1
取单个时间单位,所以问题是:给定n
, 号码是多少 i
(即 while
循环的数量)?
让我们看看每次迭代的 s 值:
iteration value of s
1 s+1
2 s+1+2
3 s+1+2+3
4 s+1+2+3+4
很明显,在i
之后迭代,s
的值是1..i之和,即i*(i+1)/2。
自 s<=n
, 然后 i*(i+1)/2<=n
所以i~Sqrt(2n)
.
编辑
一个简单的C#代码看上面:
int iterate(int n)
{
int s = 0;
int i = 1;
while (s < n)
{
s = s + i;
i = i + 1;
Console.WriteLine("s: {0}, i: {1} (Sqrt(2s): {2})",s,i,Math.Ceiling(Math.Sqrt(2*s)));
}
return i;
}
void Main()
{
iterate(1000);
}
生成下表(请参阅数字 i
与我们的 Sqrt(2s)
匹配):
s: 1, i: 2 (Sqrt(2s): 2)
s: 3, i: 3 (Sqrt(2s): 3)
s: 6, i: 4 (Sqrt(2s): 4)
s: 10, i: 5 (Sqrt(2s): 5)
s: 15, i: 6 (Sqrt(2s): 6)
s: 21, i: 7 (Sqrt(2s): 7)
s: 28, i: 8 (Sqrt(2s): 8)
s: 36, i: 9 (Sqrt(2s): 9)
s: 45, i: 10 (Sqrt(2s): 10)
s: 55, i: 11 (Sqrt(2s): 11)
s: 66, i: 12 (Sqrt(2s): 12)
s: 78, i: 13 (Sqrt(2s): 13)
s: 91, i: 14 (Sqrt(2s): 14)
s: 105, i: 15 (Sqrt(2s): 15)
s: 120, i: 16 (Sqrt(2s): 16)
s: 136, i: 17 (Sqrt(2s): 17)
s: 153, i: 18 (Sqrt(2s): 18)
s: 171, i: 19 (Sqrt(2s): 19)
s: 190, i: 20 (Sqrt(2s): 20)
s: 210, i: 21 (Sqrt(2s): 21)
s: 231, i: 22 (Sqrt(2s): 22)
s: 253, i: 23 (Sqrt(2s): 23)
s: 276, i: 24 (Sqrt(2s): 24)
s: 300, i: 25 (Sqrt(2s): 25)
s: 325, i: 26 (Sqrt(2s): 26)
s: 351, i: 27 (Sqrt(2s): 27)
s: 378, i: 28 (Sqrt(2s): 28)
s: 406, i: 29 (Sqrt(2s): 29)
s: 435, i: 30 (Sqrt(2s): 30)
s: 465, i: 31 (Sqrt(2s): 31)
s: 496, i: 32 (Sqrt(2s): 32)
s: 528, i: 33 (Sqrt(2s): 33)
s: 561, i: 34 (Sqrt(2s): 34)
s: 595, i: 35 (Sqrt(2s): 35)
s: 630, i: 36 (Sqrt(2s): 36)
s: 666, i: 37 (Sqrt(2s): 37)
s: 703, i: 38 (Sqrt(2s): 38)
s: 741, i: 39 (Sqrt(2s): 39)
s: 780, i: 40 (Sqrt(2s): 40)
s: 820, i: 41 (Sqrt(2s): 41)
s: 861, i: 42 (Sqrt(2s): 42)
s: 903, i: 43 (Sqrt(2s): 43)
s: 946, i: 44 (Sqrt(2s): 44)
s: 990, i: 45 (Sqrt(2s): 45)
s: 1035, i: 46 (Sqrt(2s): 46)
关于big-o - 时间复杂度——大O,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33002871/
多数元素问题: Given an array of size n, find the majority element. The majority element is the element tha
我有一个简单的问题来找到数组 A 中的第一个唯一元素。但是,令我困扰的是使用不同方法的时间复杂度。到目前为止,我已经尝试过这两种方法。 第一种方法: LinkedHashMap> map = new
STL 中valarray::min 和valarray::max 函数的时间复杂度是多少? 此外,什么是查找各种其他 STL 组件的时间/空间复杂性的良好来源? 最佳答案 O(N) 这些函数不会缓存
我目前正在学习复杂性(或效率,不管你怎么调用它),我在我得到的一本书中读到了它。写了一些我觉得很无意义的东西,我需要一个解释。我试过在线查找,但我没有找到他们给出的这个特定示例的答案。 For an
如何分析算法?是什么让快速排序具有 O(n^2) 的最坏情况性能,而合并排序具有 O(n log(n)) 的最坏情况性能? 最佳答案 这是整个学期的主题。最终,我们讨论的是在算法完成之前必须完成的操作
有谁知道最流行的数据库的 SQL LIKE 运算符的复杂度是多少? 最佳答案 让我们分别考虑三个核心案例。此讨论是特定于 MySQL 的,但也可能适用于其他 DBMS,因为索引通常以类似的方式实现。
Go 编程语言中这个循环的计算复杂度是多少? var a []int for i := 0 ; i doublecap { newcap = cap } else {
我需要创建一个查找函数,其中 (X,Y) 对对应于特定的 Z 值。对此的一个主要要求是我需要尽可能接近 O(1) 复杂度。我的计划是使用 unordered_map。 我通常不使用哈希表进行查找,因为
快速提问,主要满足我对该主题的好奇心。 我正在编写一些带有 SQlite 数据库后端的大型 python 程序,并且将来会处理大量记录,因此我需要尽可能优化。 对于一些功能,我正在通过字典中的键进行搜
Go 编程语言中这个循环的计算复杂度是多少? var a []int for i := 0 ; i doublecap { newcap = cap } else {
我有这个方法: public static int what(String str, char start, char end) { int count=0; for(int i=0;
for (i = 0; i i; j--) //some code that yields O(1) } 我认为上面的代码会产生 n*log(n) 但我看到另一个消息来源说它真的是 n^2
我对 InnoDB 中 OFFSET 的复杂性有疑问。我知道这主要适用于线性复杂性,但如果我在字段上有索引?! 示例: CREATE TABLE `person_rand` ( `p_id` int
我嵌套了一些 if/else 语句,但我想减少它们的开销。 在示例中,我正在评估从哪个下拉列表中单击了 li 项目,以及该 li 项目是否是第一个 (currentIndex === 0)。 代码:
这是我的第一个问题,所以我希望我没有违反任何规则。我终于设法为基数排序算法编写代码,但我想知道我是否做错了。让我觉得我的算法看起来复杂度为 O(n^3),但众所周知,基数排序是一个 O(k.n) 算法
几周前我认识了 big-O 并试图掌握它,但是尽管有很多关于计算时间复杂度的 Material ,但我似乎无法找到如何使算法更高效。 我一直在练习 Codility 中的演示挑战: Write a f
在最近的一次考试中,我们得到了一个函数来计算在未排序的 ArrayList 中出现了多少个 double (不是原始 double,而是一个项目出现两次的次数)。 我正确地确定了 Big O 复杂度为
以下循环的大 O 复杂度是多少: for each vertex u ∈ C do for each vertex v ∈ C and v > u do 我在这里做的是想象以下集合 {
我想对条款进行排序,使每个条款都是下一个条款的大 O √n√logn √n log( n^30) n/〖(logn)〗^2 〖16〗^(log√n) 谁能帮忙找到顺序? 最佳答案 claim :16
我正在尝试计算此选择排序实现的大 O 时间复杂度: void selectionsort(int a[], int n) { int i, j, mini
我是一名优秀的程序员,十分优秀!