如何计算传统for循环的运行时间
how to calculate the run time of a Traditional for loop
如何计算这个传统for循环的运行时间:
for (i = 1; i < N; ++i)
{
...statements that require exactly i operations...
}
拜托,有人愿意解释一下吗?!!
这个问题在SO上已经问过很多次了…
取自复杂度和大o符号:
循环执行N次,因此语句序列也执行N次。因为我们假设语句是O(1),所以总的时间for循环是N * O(1),总共是O(N)。
所以基本上,不可能确定for循环所花费的时间。这需要多少时间是有人为因素的。例如:
- 数组大小。
- 你正在循环的对象是什么?
- 你在循环中做了什么会影响完成每个循环的时间复杂度?
等。等。
如果你想具体计算for loop
所需的时间,那么你需要添加一些东西来确定每个循环之间的时间,无论你试图用什么语言编写代码。
顺便说一下,你从index 1
开始你的for循环,跳过第一个index 0
。
对于这类问题,您应该做的是查看循环将根据输入执行多少次迭代。例如,
for (i = 1; i < N; ++i);
这个for循环将迭代N - 1
次,因为i
从1开始,循环在i == N
.
Google不咬你:
http://www.tutorialspoint.com/c_standard_library/time_h.htm相关文章:
- 如何在C++中从两个单独的for循环中添加两个数组
- 为什么我的for循环不能正确获取argv
- 在基于范围的for循环中使用结构化绑定声明
- 通过for循环使用用户输入填充列表
- 使用for循环检查数组中的重复项
- 在for循环中使用auto vs decltype(vec.size())来处理字符串的向量
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 正在使用for循环创建QScatterSerie
- Python中的for循环与C++有何不同
- 在更改for循环的第三部分后,未使用for循环结果
- 在 for 循环中查找问题时遇到困难
- 嵌套for循环C++的问题(初学者)
- 如何用for循环在c++中生成单词三角形
- 如何在for循环中包含两个索引值的测试条件
- 带有多个独立参数的C++For循环
- 为什么我的程序在for循环中k=0时返回垃圾值
- 如何通过替换顺序代码的while循环来添加OpenMP for循环
- C++-For循环未执行
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- C++ 无法在字符数组中使用 for 循环打印字母模式