数据结构——算法效率

算法效率的度量

1.度量

  1. 算法采用的策略、方案

  2. 编译产生的代码质量

  3. 问题的输入规模

  4. 机器执行指令的速度

2.算法

​ 算法效率研究的是算法随着输入规模扩大增长量的一个抽象,不是精准的执行多少次

2.1函数的渐进增长

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YLkxLjrl-1646382391396)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220304143605835.png)]

对于两个函数f(n)g(n),当有一个整数N,n>N时,f(n)>g(n),我们就说在n以后f(n)的增长率比g(n)大

最高次项越大的函数,随着n增长,结果也会增长特别快

结论:判断一个算法的效率时,我们通常去判断它的最高次项,一般忽略次要项,项前数字也可以忽视

2.2算法时间复杂度与空间复杂度

定义:在计算分析时,语句总的执行次数T(n)是关于问题规模n的函数,进而分析T(n)随n的变化情况并确定T(n)的数量级。算法的时间复杂度,也就是算法的时间量度,记作:T(n)=O(f(n))。它表示岁问题规模n的增大,算法执行时间的增长率和f(n)的增长率相同,称作算法的渐进时间复杂度,简称为时间复杂度,其中f(n)是问题规模n的某个函数。

​ 三个求和算法 1 n n^2

​ 求O阶

1.所有的常数用1代替
2.如果最高阶存在且不是1,则去除这个项前的常数
3.得到的结果就是O

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DBUmcEUp-1646382353371)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220304145356622.png)]

对于此函数
每次函数都是i*2后在进行比较,所以假设有x个2相乘运行次数n=x*2
i=log(2)n
O(log(n))

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RFxyNCd6-1646382353371)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220304145549409.png)]

O(n)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IJ7nLYBn-1646382353371)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220304145633054.png)]

O(n^2)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1nlv1Pld-1646382443439)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220304145656971.png)]

O(n^3)

常用的时间复杂度耗费的时间从小到大:

O(1)<O(logn)<O(n)<O(n2)<O(n3)<O(2n)<O(n!)<O(nn)

时间复杂度来指运行时间的需求,空间复杂度来指空间的需求

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数据结构算法在Java中是密切相关的。数据结构是一门研究组织数据方式的学科,而算法则是处理数据的方法。在Java中,学习好数据结构可以帮助我们编写更漂亮、更高效的代码。数据结构算法的基础,想要学好算法就需要将数据结构学到位。\[1\] 在Java中,我们可以使用各种数据结构算法来解决问题。常见的数据结构包括数组、链表、栈、队列、树、图等。而算法则是对这些数据结构进行操作和处理的方法。通过选择合适的数据结构算法,我们可以提高程序的效率和性能。 在Java中,我们可以使用Java集合框架中提供的数据结构,如ArrayList、LinkedList、HashMap等。这些数据结构已经被封装好,我们可以直接使用它们来解决问题。同时,我们也可以根据具体的需求,自己实现一些特定的数据结构算法。 如果想深入了解Java中的数据结构算法,可以参考一些相关的资料和链接。比如,可以了解Java中的哈希算法及HashMap的底层实现原理,以及常用的数据结构集合框架对比总结。\[2\] \[3\] 总之,数据结构算法在Java中是相互依赖的。学习好数据结构可以帮助我们更好地理解和应用算法,而学习好算法则可以提高我们解决问题的效率和质量。 #### 引用[.reference_title] - *1* [数据结构算法【Java版】:第一课](https://blog.csdn.net/sum_12/article/details/115621379)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Java——数据结构算法](https://blog.csdn.net/m0_64359609/article/details/124174183)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [数据结构算法——Java版](https://blog.csdn.net/su2231595742/article/details/120618818)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值