java程序员必知的十种程序算法.docx
- 文档编号:16985331
- 上传时间:2023-07-21
- 格式:DOCX
- 页数:7
- 大小:105.15KB
java程序员必知的十种程序算法.docx
《java程序员必知的十种程序算法.docx》由会员分享,可在线阅读,更多相关《java程序员必知的十种程序算法.docx(7页珍藏版)》请在冰点文库上搜索。
java程序员必知的十种程序算法
java程序员必学十种程序算法
算法1:
迅速排序算法
迅速排序是由东尼·霍尔所发展一种排序算法。
在平均状况下,排序n个项目要Ο(nlogn)次比较。
在最坏状况下则需要Ο(n2)次比较,但这种状况并不常用。
事实上,迅速排序普通明显比其她Ο(nlogn)算法更快,由于它内部循环(innerloop)可以在大某些架构上很有效率地被实现出来。
迅速排序使用分治法(Divideandconquer)方略来把一种串行(list)分为两个子串行(sub-lists)。
算法环节:
1从数列中挑出一种元素,称为“基准”(pivot),
2重新排序数列,所有元素比基准值小摆放在基准前面,所有元素比基准值大摆在基准背面(相似数可以到任一边)。
在这个分区退出之后,该基准就处在数列中间位置。
这个称为分区(partition)操作。
3递归地(recursive)把不大于基准值元素子数列和不不大于基准值元素子数列排序。
递归最底部情形,是数列大小是零或一,也就是永远都已经被排序好了。
虽然始终递归下去,但是这个算法总会退出,由于在每次迭代(iteration)中,它至少会把一种元素摆到它最后位置去。
算法2:
堆排序算法
堆排序(Heapsort)是指运用堆这种数据构造所设计一种排序算法。
堆积是一种近似完全二叉树构造,并同步满足堆积性质:
即子结点键值或索引总是不大于(或者不不大于)它父节点。
堆排序平均时间复杂度为Ο(nlogn)。
算法环节:
创立一种堆H[0..n-1]
把堆首(最大值)和堆尾互换
3.把堆尺寸缩小1,并调用shift_down(0),目是把新数组顶端数据调节到相应位置
4.重复环节2,直到堆尺寸为1
算法3:
归并排序
归并排序(Mergesort,台湾译作:
合并排序)是建立在归并操作上一种有效排序算法。
该算法是采用分治法(DivideandConquer)一种非常典型应用。
算法环节:
1.申请空间,使其大小为两个已经排序序列之和,该空间用来存储合并后序列
2.设定两个指针,最初位置分别为两个已经排序序列起始位置
3.比较两个指针所指向元素,选取相对小元素放入到合并空间,并移动指针到下一位置
4.重复环节3直到某一指针达到序列尾
5.将另一序列剩余所有元素直接复制到合并序列尾
算法4:
二分查找算法
二分查找算法是一种在有序数组中查找某一特定元素搜索算法。
搜素过程从数组中间元素开始,如果中间元素正好是要查找元素,则搜素过程结束;如果某一特定元素不不大于或者不大于中间元素,则在数组不不大于或不大于中间元素那一半中查找,并且跟开始同样从中间元素开始比较。
如果在某一环节数组为空,则代表找不到。
这种搜索算法每一次比较都使搜索范畴缩小一半。
折半搜索每次把搜索区域减少一半,时间复杂度为Ο(logn)。
算法5:
线性查找算法
BFPRT算法解决问题十分典型,即从某n个元素序列中选出第k大(第k小)元素,通过巧妙分析,BFPRT可以保证在最坏状况下仍为线性时间复杂度。
该算法思想与迅速排序思想相似,固然,为使得算法在最坏状况下,依然能达到o(n)时间复杂度,五位算法作者做了精妙解决。
算法环节:
1.将n个元素每5个一组,提成n/5(上界)组。
2.取出每一组中位数,任意排序办法,例如插入排序。
3.递归调用selection算法查找上一步中所有中位数中位数,设为x,偶数个中位数状况下设定为选用中间小一种。
4.用x来分割数组,设不大于等于x个数为k,不不大于x个数即为n-k。
5.若i==k,返回x;若i
终结条件:
n=1时,返回即是i小元素。
算法6:
深度优先搜索
深度优先搜索算法(Depth-First-Search),是搜索算法一种。
它沿着树深度遍历树节点,尽量深搜索树分支。
当节点v所有边都己被探寻过,搜索将回溯到发现节点v那条边起始节点。
这一过程始终进行到已发现从源节点可达所有节点为止。
如果还存在未被发现节点,则选取其中一种作为源节点并重复以上过程,整个进程重复进行直到所有节点都被访问为止。
DFS属于盲目搜索。
深度优先搜索是图论中典型算法,运用深度优先搜索算法可以产生目的图相应拓扑排序表,运用拓扑排序表可以以便解决诸多有关图论问题,如最大途径问题等等。
普通用堆数据构造来辅助实现DFS算法。
深度优先遍历图算法环节:
1.访问顶点v;
2.依次从v未被访问邻接点出发,对图进行深度优先遍历;直至图中和v有途径相通顶点都被访问;
3.若此时图中尚有顶点未被访问,则从一种未被访问顶点出发,重新进行深度优先遍历,直到图中所有顶点均被访问过为止。
上述描述也许比较抽象,举个实例:
DFS在访问图中某一起始顶点v后,由v出发,访问它任一邻接顶点w1;再从w1出发,访问与w1邻接但还没有访问过顶点w2;然后再从w2出发,进行类似访问,…如此进行下去,直至到达所有邻接顶点都被访问过顶点u为止。
接着,退回一步,退到前一次刚访问过顶点,看与否尚有其他没有被访问邻接顶点。
如果有,则访问此顶点,之后再从此顶点出发,进行与前述类似访问;如果没有,就再退回一步进行搜索。
重复上述过程,直到连通图中所有顶点都被访问过为止。
算法7:
广度优先搜索
广度优先搜索算法(Breadth-First-Search),是一种图形搜索算法。
简朴说,BFS是从根节点开始,沿着树(图)宽度遍历树(图)节点。
如果所有节点均被访问,则算法中断。
BFS同样属于盲目搜索。
普通用队列数据构造来辅助实现BFS算法。
算法环节:
1.一方面将根节点放入队列中。
2.从队列中取出第一种节点,并检查它与否为目的。
如果找到目的,则结束搜寻并回传成果。
否则将它所有尚未检查过直接子节点加入队列中。
3.若队列为空,表达整张图都检查过了——亦即图中没有欲搜寻目的。
结束搜寻并回传“找不到目的”。
4.重复环节2。
算法8:
Dijkstra算法
戴克斯特拉算法(Dijkstra’salgorithm)是由荷兰计算机科学家艾兹赫尔·戴克斯特拉提出。
迪科斯彻算法使用了广度优先搜索解决非负权有向图单源最短途径问题,算法最后得到一种最短途径树。
该算法惯用于路由算法或者作为其她图算法一种子模块。
该算法输入包括了一种有权重有向图G,以及G中一种来源顶点S。
咱们以V表达G中所有顶点集合。
每一种图中边,都是两个顶点所形成有序元素对。
(u,v)表达从顶点u到v有途径相连。
咱们以E表达G中所有边集合,而边权重则由权重函数w:
E→[0,∞]定义。
因而,w(u,v)就是从顶点u到顶点v非负权重(weight)。
边权重可以想像成两个顶点之间距离。
任两点间途径权重,就是该途径上所有边权重总和。
已知有V中有顶点s及t,Dijkstra算法可以找到s到t最低权重途径(例如,最短途径)。
这个算法也可以在一种图中,找到从一种顶点s到任何其她顶点最短途径。
对于不含负权有向图,Dijkstra算法是当前已知最快单源最短途径算法。
算法环节:
1.初始时令S={V0},T={别的顶点},T中顶点相应距离值
若存在
若不存在
2.从T中选用一种其距离值为最小顶点W且不在S中,加入S
3.对别的T中顶点距离值进行修改:
若加进W作中间顶点,从V0到Vi距离值缩短,则修改此距离值
重复上述环节2、3,直到S中包括所有顶点,即W=Vi为止
算法9:
动态规划算法
动态规划(Dynamicprogramming)是一种在数学、计算机科学和经济学中使用,通过把原问题分解为相对简朴子问题方式求解复杂问题办法。
动态规划经常合用于有重叠子问题和最优子构造性质问题,动态规划办法所耗时间往往远少于朴素解法。
动态规划背后基本思想非常简朴。
大体上,若要解一种给定问题,咱们需要解其不同某些(即子问题),再合并子问题解以得出原问题解。
普通许多子问题非常相似,为此动态规划法试图仅仅解决每个子问题一次,从而减少计算量:
一旦某个给定子问题解已经算出,则将其记忆化存储,以便下次需要同一种子问题解之时直接查表。
这种做法在重复子问题数目关于输入规模呈指数增长时特别有用。
关于动态规划最典型问题当属背包问题。
算法环节:
1.最优子构造性质。
如果问题最优解所包括子问题解也是最优,咱们就称该问题具备最优子构造性质(即满足最优化原理)。
最优子构造性质为动态规划算法解决问题提供了重要线索。
2.子问题重叠性质。
子问题重叠性质是指在用递归算法自顶向下对问题进行求解时,每次产生子问题并不总是新问题,有些子问题会被重复计算多次。
动态规划算法正是运用了这种子问题重叠性质,对每一种子问题只计算一次,然后将其计算成果保存在一种表格中,当再次需要计算已经计算过子问题时,只是在表格中简朴地查看一下成果,从而获得较高效率。
算法10、朴素贝叶斯分类算法
朴素贝叶斯分类算法是一种基于贝叶斯定理简朴概率分类算法。
贝叶斯分类基本是概率推理,就是在各种条件存在不拟定,仅知其浮现概率状况下,如何完毕推理和决策任务。
概率推理是与拟定性推理相相应。
而朴素贝叶斯分类器是基于独立假设,即假设样本每个特性与其她特性都不有关。
朴素贝叶斯分类器依托精准自然概率模型,在有监督学习样本集中能获获得非常好分类效果。
在许多实际应用中,朴素贝叶斯模型参数预计使用最大似然预计办法,换言之朴素贝叶斯模型能工作并没有用到贝叶斯概率或者任何贝叶斯模型。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- java 程序员 程序 算法