大O -嵌套For循环逐个循环分解
Big O - Nested For Loop Breakdown Loop by Loop
我理解如何获得嵌套循环的大O的一般图片,但是嵌套for循环中的每个循环的操作是什么?
如果我们有:
for(int i=0; i<n; i++)
{
for(int j=i+1; j<1000; j++)
{
do something of constant time;
}
}
我们如何得到T(N)?外面的for循环是n个操作,里面的是1000(n-1)里面的是c,对吧?
那么T(n)=cn(1000(n-1))
对吗?
您想要折叠循环并执行双重求和。当i = 0时,运行1000-1次。当i = 1时,运行1000 - 2次,以此类推,直到n-1。这等价于从i = 0到n对级数999 - i求和,注意你可以把这两项分开得到999 n - n (n - 1)/2。
这是一个非常奇怪的公式,因为一旦n达到1000,内环立即短路,什么都不做。在这种情况下,那么,渐近时间复杂度实际上是O(n),因为对于n的高值,代码将在常数时间内跳过内部循环。
相关文章:
- 如何循环打印顶点结构
- 通过递归进行因子分解
- 如何在C++中从两个单独的for循环中添加两个数组
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 正在尝试了解输入验证循环
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- 有人能分解一下这个c++模板的语法吗
- 循环后如何继续阅读
- Ardunio UNO解决了多个重叠的定时器循环
- Eigen如何在容器循环中干净地附加矩阵
- 在某些循环内使用vector.push_back时出现分段错误
- 我正在使用嵌套的while循环来解析具有多行的文本文件,但由于某种原因,它只通过第一行,我不知道为什么
- 为什么我的for循环不能正确获取argv
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- while循环中while循环的时间复杂度是多少
- C++中的高效循环缓冲区,它将被传递给C样式数组函数参数
- 为什么在这个代码结束循环中没有得到结束
- 如何分解嵌套的循环?
- 将一个循环分解为两个循环的性能
- 大O -嵌套For循环逐个循环分解