1.2.2 算法的时间复杂度

那么我们如何评估算法的时间开销?

存在什么问题?

和机器性能有关,如:超级计算机 v.s. 单片机

和编程语言有关,越高级的语言执行效率越低

和编译程序产生的机器指令质量有关

有些算法是不能事后再统计的,如:导弹控制算法 能否事先估计?

cpp 复制代码
//算法1一逐步递增型爱你 
void loveYou(int n){//n 为问题规模 
1.int i=1; //爱你的程度
2.while(i<=n){
3.i++; //每次+1
4.printf("I Love You %d\n", i);
  }
5.printf("I Love You More Than %d\n", n);

语句频度:

1 --1次

2 --3001次

3,4 --3000次

5 --1次

T(3000)==1+3001+3000*2+1

时间开销T与问题规模n的关系:

T = 3*n+3

问题1:是否可以忽略表达式某些部分?

当问题规模足够大的时候,可以只考虑阶数高的部分。

那么如何比较两项的阶数呢?

公式:常对幂指阶

问题2:如果有好几千行代码按这种方法需要一行一行数?

相关推荐
夜思红尘5 小时前
算法--双指针
python·算法·剪枝
散峰而望5 小时前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
CoderCodingNo5 小时前
【GESP】C++五级真题(贪心思想考点) luogu-B4071 [GESP202412 五级] 武器强化
开发语言·c++·算法
我有一些感想……5 小时前
An abstract way to solve Luogu P1001
c++·算法·ai·洛谷·mlp
前端小L5 小时前
双指针专题(三):去重的艺术——「三数之和」
javascript·算法·双指针与滑动窗口
智者知已应修善业6 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
LYFlied7 小时前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
多米Domi0117 小时前
0x3f 第19天 javase黑马81-87 ,三更1-23 hot100子串
python·算法·leetcode·散列表
历程里程碑7 小时前
滑动窗口最大值:单调队列高效解法
数据结构·算法·leetcode
課代表8 小时前
从初等数学到高等数学
算法·微积分·函数·极限·导数·积分·方程