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:如果有好几千行代码按这种方法需要一行一行数?

相关推荐
talenteddriver25 分钟前
java: Java8以后hashmap扩容后根据高位确定元素新位置
java·算法·哈希算法
跨境猫小妹1 小时前
2025 TikTok Shop:从内容爆发到系统化深耕的商业跃迁
大数据·人工智能·算法·产品运营·亚马逊
不穿格子的程序员1 小时前
从零开始写算法 —— 二叉树篇 1:二叉树的三种遍历(递归实现法)
算法·深度优先·二叉树遍历·fds
子夜江寒1 小时前
逻辑森林与贝叶斯算法简介
算法·机器学习
xu_yule1 小时前
算法基础-背包问题(01背包问题)
数据结构·c++·算法·01背包
我不是小upper2 小时前
从理论到代码:随机森林 + GBDT+LightGBM 融合建模解决回归问题
人工智能·深度学习·算法·随机森林·机器学习·回归
budingxiaomoli2 小时前
分治算法-快排
数据结构·算法
云泽8082 小时前
C++ STL 栈与队列完全指南:从容器使用到算法实现
开发语言·c++·算法
前端小白在前进3 小时前
力扣刷题:复原IP地址
tcp/ip·算法·leetcode
yaoh.wang3 小时前
力扣(LeetCode) 94: 二叉树的中序遍历 - 解法思路
python·算法·leetcode·面试·职场和发展·二叉树·跳槽