本节给出了确定重复、序列和选择语句的 Big O 的几个示例。
考虑以下循环的时间复杂度:
for (int i = 1; i
k = k 5;
}
这是一个常数时间,c,用于执行
k = k 5;
由于循环执行了n次,所以循环的时间复杂度为
T(n) = (常数 c)*n = O(n).
理论分析预测了算法的性能。为了了解该算法的执行情况,我们运行下面程序中的代码来获取 n = 1000000、10000000、100000000 和 100000000 时的执行时间。
我们的分析预测了该循环的线性时间复杂度。如示例输出所示,当输入大小增加 10 倍时,运行时间大约增加 10 倍。执行结果证实了预测。
以下循环的时间复杂度是多少?
for (int i = 1; i
for (int j = 1; j
k = k i j;
}
}
这是一个常数时间,c,用于执行
k = k i j;
外循环执行n次。对于外循环中的每次迭代,内循环都会执行 n 次。因此,循环的时间复杂度为
T(n) = (常数 c)*n*n = O(n^2)
时间复杂度为 O(n^2) 的算法称为二次算法,它表现出二次增长率。随着问题规模的增加,二次算法会快速增长。如果将输入大小加倍,算法的时间就会增加四倍。具有嵌套循环的算法通常是二次的。
考虑以下循环:
for (int i = 1; i
for (int j = 1; j
k = k i j;
}
}
外循环执行n次。对于 i = 1, 2, c ,内循环执行一次、两次和 n 次。因此,循环的时间复杂度为
考虑以下循环:
for (int i = 1; i
for (int j = 1; j
k = k i j;
}
}
内循环执行20次,外循环执行n次。因此,循环的时间复杂度为
T(n) = 20*c*n = O(n)
考虑以下序列:
for (int j = 1; j
k = k 4;
}
for (int i = 1; i
for (int j = 1; j
k = k i j;
}
}
第一个循环执行10次,第二个循环执行20 * n次。因此,循环的时间复杂度为
T(n) = 10*c 20*c*n = O(n)
考虑以下选择语句:
if (list.contains(e)) {
System.out.println(e);
}
别的
for (对象 t: 列表) {
System.out.println(t);
}
假设列表包含n个元素。 list.contains(e) 的执行时间为 O(n)。 else 子句中的循环需要 O(n) 时间。因此,整个语句的时间复杂度为
考虑整数 n 的 a^n 计算。一个简单的算法将 a 乘以 n 次,如下所示:
结果 = 1;
for (int i = 1; i
结果*=a;
该算法需要 O(n) 时间。不失一般性,假设 n = 2^k。您可以使用以下方案改进算法:
结果 = a;
for (int i = 1; i
结果 = 结果 * 结果;
该算法需要 O(logn) 时间。对于任意的n,可以修改算法,证明复杂度仍然是O(logn)。
为了简单起见,由于 0(logn) = 0(log2n) = 0(logan),所以省略了常量基数。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3