寻找生长功能
Finding growth Function
我正在尝试找到给定代码的增长函数。
int sum = 0;
for (int k = n; k > 0; k /= 2) {
cout<<k<<endl;
for (int i = 0; i < k; i++)
{
sum++;
cout<<i<<endl;
}
}
但是我被困在第一个循环中(int k = n; k > 0; k /= 2)
,它以这种方式执行:
for n = 5 , it executes 3 times
n = 10 , 4 times
n = 100 , 7 times
n = 1000 , 10 times
我怎样才能概括它?
首先,10 大约是 1000 的log_2。外循环大约有 log_2(n( 次迭代。但是,这并不能告诉您总步数,因为您在内部执行的步数是可变的。
n + n/2 + n/4 + n/8 + ... = 2n = O(n(。你在循环中执行的操作数量恒定,因此步骤总数为 O(n(。大约一半的时间花在外循环的第一次迭代上,当 k=n 时。
在每一步k
被分成两半。您需要削减多少次才能归零?
1 次切割后,您有 n/2
.
切割 2 次后,您有 n/4
.
3 次切割后,您有 n/8
.
经过 4 次切割后,您有 n/16
.
5 次切割后,您有 n/32
.x
削减后,您n/2x
.
那么,还要多久才能n = 2x
?
答案很简单:x = log2(n)
.
您的循环以log n
时间运行。
但是内部循环在这些部件的大小上运行。第一次运行的大小为 n
,第二次运行是n/2
的,第三次是n/4
的,依此类推。此内部循环的所有运行的总和为:
n + n/2 + n/4 + n/8 + ... = 2n
.
因此,总运行时间等于 O(n)
(感谢道格拉斯·扎尔!
相关文章:
- 在执行其他功能的同时播放动画(LED矩阵和Arduino/ESP8266)
- 多态性和功能结合
- 带内存和隔离功能的SQLite
- 在CMakeLists.txt的安装功能中使用.cmake文件有什么用
- 类模板的成员功能的定义在单独的TU中完全专业化
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++中获得"静态纯虚拟"功能?
- 两个文件使用彼此的功能-如何解决
- 我应该实现右值推送功能吗?我应该使用std::move吗
- QML按钮点击功能执行顺序
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 有没有可能有一个只有ADL才能找到的非好友功能
- 功能样式转换从 'int' 到 'ItemType' 的匹配转换
- 文件系统:复制功能的速度秘诀是什么
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 如何在Directwrite中获得给定字体的可用OpenType功能
- 对可变参数使用声明.如何选择正确的功能
- 询问在设计我的手臂模拟器功能表示格式1
- 功能原型的目的
- 寻找生长功能