博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Algorithms学习笔记-Chapter0序言
阅读量:5278 次
发布时间:2019-06-14

本文共 803 字,大约阅读时间需要 2 分钟。

0.开篇

《Algorithms》源自Berkeley和UCSD课程讲义,由   Sanjoy Dasgupta / Christos H. Papadimitriou / Umesh Vazirani 编写。

豆瓣链接:

中文版:

1.Algorithm

伴随数字系统的发展,算法“Algorithm”作为计算方法逐渐发展壮大,推动了社会发展。

设计算法需要注意的三个问题:

  • 算法是否正确
  • 算法性能怎样/复杂度多少?
  • 还能怎样改进?

2.Fibonacci

定义:

可知F = 20.694n,指数级。

  • 递归定义算法fib1

正确性肯定能保证,复杂度为指数级

  • 多项式算法fib2

算法复杂度为O(n)

3.O符号

前面的分析中,将一个语句抽象为一次操作,然而fib数极大的时候,两大数相乘所需时间比小整数相乘时间多很多,即“Arithmetic operations on arbitrarily large numbers cannot possibly be performed in a single, constant-time step”,所以前面的抽象并不完全合理。

随着整数增大,n位整数相乘复杂度为O(n)(见Chapter 1),因此fib2复杂度应为O(n2)。

O符号表示复杂度在常数范围内的上界。

Ω表示常数范围内的下界,而a = θ(b)表示a处于常数倍b的范围内。

4.Exercise 0.4

是否存在比fib2更快的Fibonacci算法?

利用矩阵乘积,仅需求中间矩阵的n次方。

普通的算法需要n次连乘。从矩阵的角度来考虑,该矩阵满秩,因此矩阵Mn可以分解成QTVnQ,其中Q为特征向量列组成的矩阵,V为特征值对角阵。这样只需要对求特征值的n次幂即可。

 

转载于:https://www.cnblogs.com/softwarecb/p/algorithms-C0.html

你可能感兴趣的文章
工作中收集JSCRIPT代码之(下拉框篇)
查看>>
《转载》POI导出excel日期格式
查看>>
code异常处理
查看>>
git - 搭建最简单的git server
查看>>
会话控制
查看>>
推荐一款UI设计软件Balsamiq Mockups
查看>>
Linux crontab 命令格式与详细例子
查看>>
百度地图Api进阶教程-地图鼠标左右键操作实例和鼠标样式6.html
查看>>
游标使用
查看>>
LLBL Gen Pro 设计器使用指南
查看>>
SetCapture() & ReleaseCapture() 捕获窗口外的【松开左键事件】: WM_LBUTTONUP
查看>>
Android 设置界面的圆角选项
查看>>
百度地图api服务端根据经纬度得到地址
查看>>
CSS中隐藏内容的3种方法及属性值
查看>>
每天一个linux命令(1):ls命令
查看>>
根据xml生成相应的对象类
查看>>
查看ASP.NET : ViewState
查看>>
Android StageFrightMediaScanner源码解析
查看>>
vue项目中开启Eslint碰到的一些问题及其规范
查看>>
循环队列实现
查看>>