算法设计与分析(原创精品)时间复杂度_复习资料(最全版)
!算法设计与分析总复习

!算法设计与分析总复习算法设计与分析是计算机科学中非常重要的一个领域,它涉及到了算法的设计、性能分析和优化等方面。
在准备考试之前,我们需要对算法设计与分析的基本概念和常用算法进行全面复习。
一、算法设计与分析基本概念1.算法的定义:算法是一系列解决特定问题的有限步骤。
2.算法的特性:算法具有明确性、有限性、确定性和输入/输出。
3.算法的正确性:算法必须能够解决问题,并得到正确的答案。
4.算法的效率:算法的时间复杂度和空间复杂度是衡量算法效率的重要指标。
二、常用算法1.排序算法:常见的排序算法包括冒泡排序、插入排序、选择排序、快速排序、归并排序等。
需要了解每种排序算法的思想、时间复杂度和空间复杂度,并能够对其进行实现和优化。
2.查找算法:常用的查找算法包括顺序查找、二分查找、哈希查找等。
需要了解每种查找算法的思想和时间复杂度,并能够对其进行实现和应用。
3. 图算法:图算法包括深度优先(DFS)、广度优先(BFS)、最短路径算法(Dijkstra算法、Floyd算法)等。
需要了解这些算法的思想、时间复杂度和应用场景,并能够对其进行实现和应用。
4.动态规划算法:动态规划算法适用于具有重叠子问题和具有最优子结构性质的问题。
需要了解动态规划算法的基本思想、时间复杂度和应用场景,并能够对具体问题进行动态规划的设计和实现。
5.贪心算法:贪心算法常用于解决最优化问题,每一步都选择当前最优解,以期最终达到全局最优解。
需要了解贪心算法的基本思想、时间复杂度和应用场景,并能够对具体问题进行贪心算法的设计和实现。
三、算法的时间复杂度和空间复杂度1. 时间复杂度:算法的时间复杂度表示算法的执行时间和输入数据规模之间的关系。
常见的时间复杂度有O(1)、O(logn)、O(n)、O(nlogn)、O(n^2)等。
需要掌握各种时间复杂度的计算方法和复杂度的比较。
2.空间复杂度:算法的空间复杂度表示算法的内存消耗和输入数据规模之间的关系。
计算机算法设计与分析期末复习资料

计算机算法设计与分析期末复习资料一填空题(20x1=20分)1.当有多个算法来解决集合问题时,选择算法的主要原则是选择复杂度最低的算法。
2.函数本身定义的函数是递归函数。
该算法适用于求解动态规划问题。
4.贪心算法的两个基本要素是最优子结构性质、贪心选择性质。
5.在搜索解空间树时,回溯方法通常使用深度优先的方法来提高搜索效率,以避免无效搜索。
6.根据不同的求解目标,分枝定界法和回溯法分别通过广度优先遍历或最小代价优先和深度优先搜索解空间树。
7.分支界限法和回溯法主要区别在于求解目标和搜索方式不同。
8.在执行分支定界法时,通常使用该方法来实现最大优先级队列。
9.依据求解所花费的时间和所得到的结果不同,随机化算法大致分为数值随机化算法、蒙特卡罗算法、拉斯维加斯算法和舍伍德算法四类。
10.产生伪随机数最常用的方法是线性同余法。
11.线性规划算法中旋转轴变化的目的是调整基准内变量和基准外变量的位置。
12.在最大网络流问题中,增广路径是剩余网络中容量大于0的路径。
13.应用于动态规划的待解决问题的两个基本要素是:。
14.算法必须满足的四个特征是输入、输出、确定性和有限性。
15.算法复杂性依赖于、、三个方面的复杂因素。
16.实现递归调用的关键是17.动态规划算法解决问题的重要线索是问题的性质。
18.最优子结构性质是贪婪算法的关键特征。
19.分支界限法的求解目标是找出满足约束条件的一个解,或是在满足约束条件的解中找出在某种意义下的最优解。
20.有两种常见的解空间树:子集树和置换树。
21.分支界限算法依据其从和节点表中选择获得下一扩展节点的不同方式被分为22.对于任何约束标准线性规划问题,只要基本变量设置为0,就可以得到一个解。
三概念题(6x2=12分)1.算法复杂度:指算法运行所需的计算机资源量。
需要时间资源的量称为时间复杂度,需要空间资源源的量称为空间复杂性。
2.递归算法:直接或间接调用自身的算法称为递归算法。
算法设计与分析复习要点

算法设计与分析的复习要点第一章:算法问题求解基础算法是对特定问题求解步骤的一种描述,它是指令的有限序列。
一.算法的五个特征:1.输入:算法有零个或多个输入量;2.输出:算法至少产生一个输出量;3.确定性:算法的每一条指令都有确切的定义,没有二义性;4.可行性:算法的每一条指令必须足够基本,它们可以通过已经实现的基本运算执行有限次来实现;5.有穷性:算法必须总能在执行有限步之后终止。
二.什么是算法?程序与算法的区别1.笼统地说,算法是求解一类问题的任意一种特殊的方法;较严格地说,算法是对特定问题求解步骤的一种描述,它是指令的有限序列。
2.程序是算法用某种程序设计语言的具体实现;算法必须可终止,程序却没有这一限制;即:程序可以不满足算法的第5个性质“有穷性”。
三.一个问题求解过程包括:理解问题、设计方案、实现方案、回顾复查。
四.系统生命周期或软件生命周期分为:开发期:分析、设计、编码、测试;运行期:维护。
五.算法描述方法:自然语言、流程图、伪代码、程序设计语言等。
六.算法分析:是指对算法的执行时间和所需空间的估算。
算法的效率通过算法分析来确定。
七.递归定义:是一种直接或间接引用自身的定义方法。
一个合法的递归定义包括两部分:基础情况和递归部分;基础情况:以直接形式明确列举新事物的若干简单对象;递归部分:有简单或较简单对象定义新对象的条件和方法八.常见的程序正确性证明方法:1.归纳法:由基础情况和归纳步骤组成。
归纳法是证明递归算法正确性和进行算法分析的强有力工具;2.反证法。
第二章:算法分析基础一.会计算程序步的执行次数(如书中例题程序2-1,2-2,2-3的总程序步数的计算)。
二.会证明5个渐近记法。
(如书中P22-25例2-1至例2-9)三.会计算递推式的显式。
(迭代法、代换法,主方法)四.会用主定理求T(n)=aT(n/b)+f(n)。
(主定理见P29,如例2-15至例2-18)五.一个好的算法应具备的4个重要特征:1.正确性:算法的执行结果应当满足预先规定的功能和性能要求;2.简明性:算法应思路清晰、层次分明、容易理解、利于编码和调试;3.效率:算法应有效使用存储空间,并具有高的时间效率;4.最优性:算法的执行时间已达到求解该类问题所需时间的下界。
算法设计与分析复习资料

1.什么是算法?算法是一系列解决问题的指令,对符合规范的输入,能在有限时间内获得预期的输出。
2.算法的特点?有穷性-有限步内完成;确定性-每一步是确定的,不能有二义性;可行性-每一步有意义,每一步能求解;输入-须检查输入值值域合法性;输出-输出问题的解,无输出的算法没有意义。
补:排序算法的特点:稳定性,在位性。
稳定性:如果一个排序算法保留了等值元素在输入中的相对顺序,他被称为是稳定的。
换句话说,如果一个输入列表包含两个相等的元素,他们的位置分别是i和j。
i<j。
而在排好序的列表中,他们的位置分别是i`和j`,那么i`<j`肯定成立。
在位性:如果一个算法不需要额外的存储空间(除了个别存储单元外),我们称它是在位的。
3.求最大公约数的伪码?Euclid(m,n)//计算m和n最大公约数的欧式算法//输入:两个不全为0的非负整数m>=n//输出:m和n的最大公约数while n≠0 do{r←m mod nm←nn←r}return m4.问题求解过程理解问题;了解设备性能选择计算方法,精确或近似接法高效的数据结构算法的设计技术;设计算法;正确性证明;分析算法;编程实现算法。
1-2-3-4-5-6.4-3,4-2,5-3,5-2(理解问题;决定:计算方法:精确或近似方法:数据结构:算法设计技术;设计算法;正确性证明;分析算法;根据算法写代码.)5.算法分析主要步骤(框架)算法的运行效率也称为计算复杂性(计算复杂度);计算复杂性:时间复杂性(时间效率)空间复杂性(空间效率)时间效率-算法运行所耗费的时间。
空间效率-算法运行所需的存储空间。
输入规模事实:几乎所有算法对更大规模的输入都要耗费更长的时间!即算法耗时随输入规模增大而增大;增长函数定义为输入规模的函数,用它来研究算法;输入规模的选择它的选择比较直接容易。
6.n元列表查找最大值-数组实现列表MaxElement(A[0..n-1])maxval←0for i←1 to n-1 doif A[i]>maxvalmaxval←A[i]return maxval7.检查数组元素是否唯一UniqueElement(A[0..n-1])for i←0 to n-2 dofor j←i+1 to n-1 doif A[i]=A[j] return falsereturn true8.计算方阵A B的矩阵乘积MatrixMultiplication(A[0..n-1][0..n-1],B[0..n-1][0..n-1])for i←0 to n-1 do//行循环for j←0 to n-1 do//列循环M[i][j]←0.0 //积矩阵初始化for k←0 to n-1 do//用变量k表示变化的脚标M[i][j]←M[i][j]+A[i][k]*B[k][j]return M9.计算十进制正整数n的二进制位数b算法的时间复杂性分析Binary(n)count←1while n>1 docount++n←「n/2「return count10.求m,n最大公约数gcd(int m,int n)//求m,n最大公约数的欧式递归版本//输入:两个正整数m≥n//输出:最大公约数{if(n=0)//递归出口,结束递归write(M);//输出结果elsegcd(n,m mod n);}11.选择排序(每次从数组中选取最小的按顺序插入) SelectionSort(A[1..n]){for i←1 to n-1 domin←ifor j←i+1 to n doif(A[j]<A[min])min←jA[i]↔A[min]}12.冒泡排序(相邻的比较,a<b则交换,最后一位则为最大) BubbleSort(A[1..n]{ for i←1 to n-1 dofor j←1 to n-i doif(A[j]>A[j+1])A[j]↔A[j+1]}13.顺序查找SequentialSearch(A[n..n],k){ A[n]←Ki←0while(A[i]≠k) i←i+1if(i<n)return(i)else return(-1)}14.串匹配BruteForceStringMatch(T[0..n-1],P[0..m-1]){for i←0 to n-m do{ j←0while j<m and P[j]=T[i+j] doj←j+1if i=m return i}return -1}15.最近对BruteForceCloserPoints(Object P[1..n]){ dmin←∞for i←1 to n-1 dofor j←1 to n dod←sqrt((Xi-Xj)2+(Yi-Yj)2)if(d<dmin){dmin←d,index1←i,index2←j}return(index1,index2)}16.分治算法DivideandConquer(s){if(|s|≤t)then adhocery(s)else{ divide s into smaller subset s1,s2,skfor i←1 to k do{Yi←DivideandConquer(Si)}return merge(Y1,Y2,Yk)}}17.分治法查找最大元素DivideandConquerSearchMax(S){ t←2if(|S|≤t)then return max(S1,S2)else{divide S into two smaller subset S1 and S2,|S1|=|S2|}=|S|/2 max1=DivideandConquerSearchMax(S1)max2=DivideandConquerSearchMax(S2)return max(max1,max2)}}18.合并排序之分治算法MergeSort(A[0..n-1]){ if(n>1){copy A[0..」n/2」-1]to B[0..」n/2」-1]copy A[」n/2」..n-1]to C[0..」n/2」]MergeSort(B)MergeSort(C)Merge(B,C,A)}}Merge(B[0..p-1],C[0..q-1],A[0..p+q-1]){i←0,j←0,k←0while i<p and j<q doif(B[i]≤C[j])A[k]←B[i],i←i+1else A[k]←B[j],j←j+1k←k+1if(i=p)copy C[j..q-1]to A[k..p+q-1]else copy B[j..q-1]to A[k..p+q-1]}19.快速排序QuickSort(A[L..R]){ if(L<R)S←Partition(A[L..R])QuickSort(A[L..S-1])QuickSort(A[S+1..R])}Partition(A[l..r])p←A[l] i←l; j←r+1repeatrepeat i←i+1 until A[i]≥prepeat j←j-1 until A[j]≥pswap(A[i],A[j])until i≥jswap(A[i],A[j]swap(A[l],A[j]return j20.两次扫描确定分区算法Partition(A[L..R]){ p←A[L]i←L+1,j←Rwhile(true){ while(A[i]<p)and(i≤R)do i←i+1while(A[j]>q)and(j≥R)do j←j-1if(i≥j)then breakswap(A[i],A[j])}swap(A[L],A[j])return (j)}21.折半查找BinarySearch(A[0..n-1],K){L←0,R←n-1while(L<R) dom←」(L+R)/2」if(K=A[m])return melse if(K<A[m])R←m-1else L←m+1return(-1)}22.插入排序(比较两个相邻的数,依次从小到大插入) InsertionSort(A[0..n-1]){ for(i←1 to n-1) doj←i-1,V←A[i]while(j≥0 and A[j]>V)A[j+1]←A[j]j←j-1A[j+1]←V}23.DFS递归版DFSRecursion(vertex v){ count←count+1visit(v)Mark[v]←countfor each vertex w adjacent to v doif Mark[w]=0 thenDFSRecursion(w)}非递归:DFS(Graph G,Vertex v){ count←0virst(v)Initialize(S)Push(v)while(isEmpty(S)=FALSE)x←Pop(S)for each vertex w adjacent to x doif Mark[w]=0 thenvirst(w),count←count+1,Mark[w]←countPush(w)}23.BFS非递归算法BFS(Graph G,Vertex v){ count←0 virst(v) Initialize(Q) Enqueue(v)while(isEmpty(Q)=FALSE)x←Dequeue(Q)for each vertex w adjacent to x doif Mark[w]=0 then virst(w),count++,Mark[w]←count Enqueue(w)}24.预排序检验数组中元素唯一性PresortElementUniqueness(A[0..n-1])For i←0 to n-2 doif A[i]=A[i+1]return falsereturn true时间效率蛮力法:2n变治法:T(n)=Tsort(n)+Tscan(n)∈O(nlogn)+O(n)∈O(nlogn)25.变治法预排序蛮力法效率:T(n)=1+…+n-1∈Θ(n*n)变治法预排序:T(n)=n-1PresortMode_1(A[0..N-1])//行程算法,对数组排序i←0,ModeFrequency←0//最大频率while(i≤n-1)runlength←1,runvalue←A[i]while(i+runlength≤n-1 and A[i+runlength]=runvalue)runlength ++if(runlength>ModeFrequency)ModeFrequency←runlength,modeValue←runvaluei←i+runlengthreturn(ModeValue,ModeFrequency26.堆构造的值交换算法HeapValueExchange(H[1..n])For i←」n/2」downto 1 dok←I,v←H[k]heap←FALSEwhile(not heap)and(2*k≤n)doj←2*k if(j+1≤n)if(H[j]<H[j+1])j←j+1if(v≥H[j] heap←TRUEelse{H[k] ←H[j],k←j}H[k] ←v时间效率T(n)=Ε(n=o,h-1)[2(h-k)2k次方]=2hΕ(k=0,h-1)2k次方-2Ε(k=1,h-1)2k次方=2(n-log2(n+1))<2n,n>027.三种贪婪策略解决01背包的过程和结果价值最大:满足约束条件下,每次装入价值最大的物品----不一定能找到最优解(背包称重量消耗过快)重量最小:满足约束条件下,每次装入重量最轻的物品---不一定找到最优解(装入总价值增加太慢)单位价值最大:满足约束条件下,每次装入价值/重量最大的物品---能找到最优解28.连续背包的贪婪算法GreedyKnapsack(n,w[1..n],v[1..n],x[1..n],W,V)X[1..n] ←0 Wo←W V←0MergeSort(v[1..n]/w[1..n])For(i←1 to n)doIf(w[i]<Wo)then x[i]←1Wo←Wo←w[i]V←V+v[i]Else x[i]←Wo/w[i], V←V+x[i]*v[i]BreakReturn V29.贪婪算法Prim算法:PrimMST(G)Vt←{vo}Et←ΦFor(i←1 to|V|-1)do在V-Vt中选与当前树最小距离的边e*=(v*,u*)Vt←Vt∪{u*}Et←Et∪{e*}Return EtDijkstra算法伪码:Dijkstre(G,s)Initialize(Q)For(each vertex v∈V)dv←∞Isert (Q,v,dv)ds←0,Decrease(Q,s,ds)Vt←ΦFor(i←0 to |V|-1)U*←DeleteMin(Q)Vt←Vt∪{u*}For(each vertex u∈(V-Vt)adjacent to u*∈Vt)If(dn*+w(u*,u)<du)du←du*+w(u*,u)Decrease(Q,u,dn)Kruskal算法:Kruskal(G)Et←∅;ecounter←0k←0while ecounter<|V|-1 dok←k+1if Et∪{Eik}无回路ET←Et∪{Eik};ecounter←ecounter+1Return Eta.设计一个蛮力算法,对于给定的x0,计算下面多项式的值:P(x)=a n x n+a n-1x n-1+…+a1x+a0并确定该算法的最差效率类型.b.如果你设计的算法属于Θ(n2),请你为该算法设计一个线性的算法.。
算法设计与分析期末备考知识点总结

算法设计与分析期末备考知识点总结●通俗地说,算法是解决咨询题的办法,严格地讲,算法是对特定咨询题求解步骤的一种描述,是指令的有限序列。
●算法还必须满脚一下五个重要特性:输入、输出、有穷性、确定性、可行性。
●程序(Program)是对一具算法使用某种程序设计语言的具体实现,原则上,算法能够用任何一种程序设计语言来实现。
啥是算法的计算复杂性?●算法分析指的是对算法所需要的两种计算机资源——时刻和空间(时刻复杂性和空间复杂性举行估算,所需要的资源越多,该算法的复杂性就越高。
●表示计算复杂性的O你掌握了?若存在两个正的常数c和n0,关于任意n≥n0,都有T(n)≤c×f(n),则称T(n)=O(f(n))(或称算法在O(f(n))中)。
我们要紧介绍了哪几种算法设计办法?分治法:将一具难以直截了当解决的大咨询题,分割成一些规模较小的子咨询题,以便各个击破,分而治之。
减治法:减治法在将原咨询题分解为若干个子咨询题后,利用了规模为n 的原咨询题的解与较小规模(通常是n/2)的子咨询题的解之间的关系,这种关系通常表现为:(1)原咨询题的解只存在于其中一具较小规模的子咨询题中;(2)原咨询题的解与其中一具较小规模的解之间存在某种对应关系。
由于原咨询题的解与较小规模的子咨询题的解之间存在这种关系,因此,只需求解其中一具较小规模的子咨询题就能够得到原咨询题的解。
动态规划法、贪心算法、回溯算法、概率RAM程序分治法------合并排序设算法4.3对n个元素排序的时刻复杂性为T(n),则该二路归并排序算法存在如下递推式:二路归并排序的时刻代价是O(nlog2n)。
所需空间只要O(m+n+min(m, n))的空间就够了(假设两个合并串的长度分不为m和n)。
分治法------快速排序在最好事情下在具有n个记录的序列中,一次划分需要对整个待划分序列扫描一遍,则所需时刻为O(n)。
时刻复杂度为O(nlog2n)。
在最坏事情下必须通过n-1次递归调用才干把所有记录定位,而且第i趟划分需要通过n-i 次关键码的比较才干找到第i个记录的基准位置,所以,总的比较次数为:时刻复杂度为O(n2)分治法------最大子段递推式:算法时刻复杂度:O(nlog2n)分治法------棋盘覆盖咨询题T(k)满脚如下递推式:分治法------循环赛日安排咨询题基本语句的执行次数是:算法的其时刻复杂性为O(4k)。
算法设计与分析复习题目及复习资料

分治法1、二分搜索算法是利用(分治策略)实现的算法。
9. 实现循环赛日程表利用的算法是(分治策略)27、Strassen矩阵乘法是利用(分治策略)实现的算法。
34.实现合并排序利用的算法是(分治策略)。
实现大整数的乘法是利用的算法(分治策略)。
17.实现棋盘覆盖算法利用的算法是(分治法)。
29、使用分治法求解不需要满足的条件是(子问题必须是一样的)。
不可以使用分治法求解的是(0/1背包问题)。
动态规划下列不是动态规划算法基本步骤的是(构造最优解)下列是动态规划算法基本要素的是(子问题重叠性质)。
下列算法中通常以自底向上的方式求解最优解的是(动态规划法)备忘录方法是那种算法的变形。
(动态规划法)最长公共子序列算法利用的算法是(动态规划法)。
矩阵连乘问题的算法可由(动态规划算法B)设计实现。
实现最大子段和利用的算法是(动态规划法)。
贪心算法能解决的问题:单源最短路径问题,最小花费生成树问题,背包问题,活动安排问题,不能解决的问题:N皇后问题,0/1背包问题是贪心算法的基本要素的是(贪心选择性质和最优子结构性质)。
回溯法回溯法解旅行售货员问题时的解空间树是(排列树)。
剪枝函数是回溯法中为避免无效搜索采取的策略回溯法的效率不依赖于下列哪些因素(确定解空间的时间)分支限界法最大效益优先是(分支界限法)的一搜索方式。
分支限界法解最大团问题时,活结点表的组织形式是(最大堆)。
分支限界法解旅行售货员问题时,活结点表的组织形式是(最小堆)优先队列式分支限界法选取扩展结点的原则是(结点的优先级)在对问题的解空间树进行搜索的方法中,一个活结点最多有一次机会成为活结点的是( 分支限界法).从活结点表中选择下一个扩展结点的不同方式将导致不同的分支限界法,以下除( 栈式分支限界法)之外都是最常见的方式.(1)队列式(FIFO)分支限界法:按照队列先进先出(FIFO)原则选取下一个节点为扩展节点。
(2)优先队列式分支限界法:按照优先队列中规定的优先级选取优先级最高的节点成为当前扩展节点。
算法分析与设计考试复习题及参考复习资料

一、简要回答下列问题:1.算法重要特性是什么?2.算法分析的目的是什么?3.算法的时间复杂性与问题的什么因素相关?4.算法的渐进时间复杂性的含义?5.最坏情况下的时间复杂性和平均时间复杂性有什么不同?6.简述二分检索(折半查找)算法的基本过程。
7.背包问题的目标函数和贪心算法最优化量度相同吗?8.采用回溯法求解的问题,其解如何表示?有什么规定?9.回溯法的搜索特点是什么?10.n皇后问题回溯算法的判别函数place的基本流程是什么?11.为什么用分治法设计的算法一般有递归调用?12.为什么要分析最坏情况下的算法时间复杂性?13.简述渐进时间复杂性上界的定义。
14.二分检索算法最多的比较次数?15.快速排序算法最坏情况下需要多少次比较运算?16.贪心算法的基本思想?17.回溯法的解(x1,x2,……x n)的隐约束一般指什么?18.阐述归并排序的分治思路。
19.快速排序的基本思想是什么。
20.什么是直接递归和间接递归?消除递归一般要用到什么数据结构?21.什么是哈密顿环问题?22.用回溯法求解哈密顿环,如何定义判定函数?23.请写出prim算法的基本思想。
二、复杂性分析1、MERGESORT(low,high)if low<high;then mid←(low,high)/2;MERGESORT(low,mid);MERGESORT(mid+1,high);MERGE(low,mid,high);endifend MERGESORT2、procedure S1(P,W,M,X,n)i←1; a←0while i≤ n doif W(i)>M then return endifa←a+ii←i+1 ;repeatend3.procedure PARTITION(m,p)Integer m,p,i;global A(m:p-1)v←A(m);i←mlooploop i←i+1 until A(i) ≥v repeatloop p←p-1 until A(p) ≤v repeatif i<pthen call INTERCHANGE(A(i),A(p))else exitendifrepeatA(m) ←A(p);A(p) ←vEnd PARTITION4.procedure F1(n)if n<2 then return(1)else return(F2(2,n,1,1))endifend F1procedure F2(i,n,x,y)if i≤nthen call F2(i+1,n,y,x+y)endifreturn(y)end F25.procedure MAX(A,n,j)xmax←A(1);j←1for i←2 to n doif A(i)>xmax then xmax←A(i); j←i;endif repeatend MAX6.procedure BINSRCH(A,n,x,j)integer low,high,mid,j,n;low←1;high←nwhile low≤high domid←|_(low+high)/2_|case:x<A(mid):high←mid-1:x>A(mid):low←mid+1:else:j←mid; returnendcaserepeatj←0end BINSRCH三、算法理解1、写出多段图最短路经动态规划算法求解下列实例的过程,并求出最优值。
算法设计与分析 复习整理汇编

《算法设计与分析》复习要点2.算法的概念:答:算法是求解一类问题的任意一种特殊的方法。
一个算法是对特定问题求解步骤的一种描述,它是指令的有限序列。
注:算法三要素:1、操作2、控制结构3、数据结构3.算法有5大特性:答:输入、输出、确定性、能行性、有穷性。
注:输入:一个算法有0个或多个输入;输出:一个算法将产生一个或多个输出。
确定性:一个算法中每一步运算的含义必须是确切的、无二义性的;可行性:一个算法中要执行的运算都是相当基本的操作,能在有限的时间内完成;有穷性:一个算法必须在执行了有穷步运算之后终止;4.算法按计算时间可分为两类:答:多项式时间算法的渐进时间复杂度:O(1)<O(logn)<O(n)<O(nlogn)<O(n^2)<O(n^3),具有此特征的问题称为P为题。
有效算法。
指数时间算法的渐进时间复杂度之间的关系为:O(2^n)<O(n!)< O(n^n),具有此特征的问题称为NP问题。
注:可以带1或2这些数字来判断它们之间的大小关系。
5.一个好算法的4大特性:答:正确性、简明性、效率、最优性。
注:正确性:算法的执行结果应当满足预先规定的功能和性能要求。
简明性:算法应思路清晰、层次分明、容易理解。
利于编码和调试。
效率:时间代价和空间代价应该尽可能的小。
最优性:算法的执行时间已经到求解该类问题所需要时间的下界。
6.影响程序运行时间的因素:1、答:程序所以来的算法。
问题规模和输入数据。
计算机系统系能。
注:算法运行的时间代价的度量不应依赖于算法运行的软件平台,算法运行的软件包括操作系统和采用的编程语言及其编译系统。
时间代价用执行基本操作(即关键操作)的次数来度量,这是进行算法分析的基础。
7.关键操作的概念答:指算法运行中起主要作用且花费最多时间的操作。
1.简述分治法是怎样的一种算法设计策略:答:将一个问题分解为若干个规模较小的子问题,且这些子问题互相独立且与原问题类型相同,递归地处理这些子问题,直到这些子问题的规模小到可以直接求解,然后将各个子问题的解合并得到原问题的解。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
O(1)
Temp=i;i=j;j=temp;
以上三条单个语句的频度均为1,该程序段的执行时间是一个与问题规模n无关的常数。
算法的时间复杂度为常数阶,记作T(n)=O(1)。
如果算法的执行时间不随着问题规模n的增加而增长,即使算法中有上千条语句,其执行时间也不过是一个较大的常数。
此类算法的时间复杂度是O(1)。
O(n^2)
2.1. 交换i和j的内容
sum=0;(一次)
for(i=1;i<=n;i++) (n次)
for(j=1;j<=n;j++) (n^2次)
sum++;(n^2次)
解:T(n)=2n^2+n+1 =O(n^2)
2.2.
for (i=1;i<n;i++)
{
y=y+1; ①
for (j=0;j<=(2*n);j++)
x++; ②
}
解:语句1的频度是n-1
语句2的频度是(n-1)*(2n+1)=2n^2-n-1
f(n)=2n^2-n-1+(n-1)=2n^2-2
该程序的时间复杂度T(n)=O(n^2). O(n)
2.3.
a=0;
b=1; ①
for (i=1;i<=n;i++) ②
{
s=a+b;③
b=a;④
a=s;⑤
}
解:语句1的频度:2,
语句2的频度:n,
语句3的频度:n-1,
语句4的频度:n-1,
语句5的频度:n-1,
T(n)=2+n+3(n-1)=4n-1=O(n).
O(log2n )
2.4.
i=1; ①
while (i<=n)
i=i*2; ②
解:语句1的频度是1,
设语句2的频度是f(n), 则:2^f(n)<=n;f(n)<=log2n
取最大值f(n)= log2n,
T(n)=O(log2n )
O(n^3)
2.5.
for(i=0;i<n;i++)
{
for(j=0;j<i;j++)
{
for(k=0;k<j;k++)
x=x+2;
}
}
解:当i=m, j=k的时候,内层循环的次数为k当i=m时, j 可以取0,1,...,m-1 , 所以这里最内循环共进行了0+1+...+m-1=(m-1)m/2次所以,i从0取到n, 则循环共进行了: 0+(1-1)*1/2+...+(n-1)n/2=n(n+1)(n-1)/6所以时间复杂度为O(n^3).
我们还应该区分算法的最坏情况的行为和期望行为。
如快速排序的最坏情况运行时间是O(n^2),但期望时间是O(nlogn)。
通过每次都仔细地选择基准值,我们有可能把平方情况(即O(n^2)情况)的概率减小到几乎等于0。
在实际中,精心实现的快速排序一般都能以(O(nlogn)时间运行。
下面是一些常用的记法:
①访问数组中的元素是常数时间操作,或说O(1)操作。
②一个算法如果能在每个步骤去掉一半数据元素,如二分检索,通常它就取O(logn)时间。
③用strcmp比较两个具有n个字符的串需要O(n)时间。
④常规的矩阵乘算法是O(n^3),因为算出每个元素都需要将n对元素相乘并加到一起,所有元素的个数是n^2。
⑤指数时间算法通常来源于需要求出所有可能结果。
例如,n个元素的集合共有2n个子集,所以要求出所有子集的算法将是O(2n)的。
:-D指数算法一般说来是太复杂了,除非n的值非常小,因为,在这个问题中增加一个元
素就导致运行时间加倍。
不幸的是,确实有许多问题(如著名的“巡回售货员问题” ),到目前为止找到的算法都是指数的。
如果我们真的遇到这种情况,通常应该用寻找近似最佳结果的算法替代之。
常见的时间复杂度,按数量级递增排列依次为:常数阶O(1)、对数阶O(log2n)、线性阶O(n)、线性对数阶O(nlog2n)、平方阶O(n^2)、立方阶O(n^3)、k次方阶O(n^k)、指数阶O(2^n)。
下面我们通过例子加以说明,让大家碰到问题时知道如何去解决。
1、设三个函数f,g,h分别为f(n)=100n^3+n^2+1000 , g(n)=25n^3+5000n^2 , h(n)=n^1.5+5000nlgn
请判断下列关系是否成立:
(1)f(n)=O(g(n))
(2)g(n)=O(f(n))
(3)h(n)=O(n^1.5)
(4)h(n)=O(nlgn)
◆(1)成立。
题中由于两个函数的最高次项都是n^3,因此当n→∞时,两个函数的比值是一个常数,所以这个关系式是成立的。
◆(2)成立。
与上同理。
◆(3)成立。
与上同理。
◆(4)不成立。
由于当n→∞时n^1.5比nlgn递增的快,所以h(n)与nlgn的比值不是常数,故不成立。
2、设n为正整数,利用大"O"记号,将下列程序段的执行时间表示为n的函数。
(1) i=1; k=0
while(i<n)
{ k=k+10*i;i++;
}
解答:T(n)=n-1,T(n)=O(n),这个函数是按线性阶递增的。
(2) x=n; // n>1
while (x>=(y+1)*(y+1))
y++;
解答:T(n)=n1/2 ,T(n)=O(n1/2),最坏的情况是y=0,那么循环的次数是n1/2次,这是一个按平方根阶递增的函数。
(3) x=91; y=100;
while(y>0)
if(x>100)
{x=x-10;y--;}
else x++;
解答:T(n)=O(1),这个程序看起来有点吓人,总共循环运行了1000次,但是我们看到n 没有? 没。
这段程序的运行是和n无关的,就算它再循环一万年,我们也不管他,只是一个
常数阶的函数。
一个经验规则
有如下复杂度关系
c < log2N < n < n * Log2N < n^2 < n^3 < 2^n < 3^n < n!
其中c是一个常量,如果一个算法的复杂度为c 、log2N 、n 、n*log2N ,那么这个算法时间效率比较高,如果是2^n , 3^n ,n!,那么稍微大一些的n就会令这个算法不能动了,居于中间的几个则差强人意。
-------------证明O(f)O(g)=O(fg)------------
根据2L和5L给出的定义,这里给个证明。
如有问题,欢迎讨论。
定义:
1. O(g(n)) = {f(n): 存在正常数c和n0,使当所有n ≥ n0时,等式0 ≤ f(n) ≤ cg(n)成立}.
2. O(f)O(g)={h:存在函数p和q,使得h = p * q,且p属于O(f), q属于O(g)}
基本思路:
O(f)O(g)和O(fg)都是集合。
要证明集合相等,只要证明二者相互包含即可。
证明步骤1:O(f)O(g)包含于O(fg)
设h属于O(f)O(g)。
由定义2知,存在函数p和q,使得h = p * q,且p属于O(f),q属于O(g)。
对于函数p,由定义1知,存在正常数c1和n1,使当所有n ≥ n1时,等式0 ≤ p(n) ≤ c1 * f(n)成立;同理,对于函数q,由定义1知,存在正常数c2和n2,使当所有n ≥ n2时,等式0 ≤ q(n) ≤ c2 * g(n)成立。
现令n0 = max(n1, n2),c = c1 * c2,当n ≥ n0时,0 ≤ p(n) * q(n) = h(n) ≤ c1 * c2 * f(n) * g(n) = c * f(n) * g(n),即h属于O(fg)(由定义2)。
因为h属于O(f)O(g),且h又属于O(fg),所以O(f)O(g)包含于O(fg)。
证明步骤2:O(fg)包含于O(f)O(g)
设h属于O(fg)。
由定义2知,存在正常数c0和n0,使当所有n ≥ n0时,等式0 ≤ h(n) ≤ c * f(n) * g(n)成立。
令函数p = h / f,q = f。
由上述不等式知,当所有n ≥ n0时,等式0 ≤ p(n) ≤ c * g(n)成立,所以p属于O(g)(定义1)。
因为q = f,易知q属于O(f)。
又由于h = p * q,根据定义2知,h属于O(f)O(g)。
因为h属于O(fg),且h又属于O(f)O(g),所以O(fg)包含于O(f)O(g)。
结论:
根据步骤1和2,命题证毕。