算法设计与分析

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

一 填空题

1. 一个计算机算法的指令序列需要满足性质的是输入、输出、确定

性、有限性。

输入、输出、确定性、有限性

2.n n 1092+的渐近表达式是 O(n 2) 3 . 下面程序段的时间复杂度是 O(n 2)

for (i=0; i

for (j=0; j

4.求两个n 阶矩形的乘法C=A*B,其算法如下:

#define MAX 100

voidmaxtrixmult( int n, float a[MAX][MAX], float c[MAX][MAX])

{ int i, j, k; float x;

for( i=1; i<=n; i++)8

{ for( j=1; j<=n; j++)

{ x=0;

for( k=1; k<=n; k++)

x+=a[i][k]*b[k][j];

c[i][j]=x;

}

}

}

该算法的时间复杂度为 O(n 3)

5.通常用来表示时间算法的有以下六种多项式: ),log (),(),(),(log ),(),1(2223n n O n O n O n O n O O 按从小到大的顺序排列

6.快速排序算法是基于分治策略的一个算法。其基本思想是,对于

输入的子数组a [p :r ],按以下3个步骤进行排序: 分解、递归求解、

合并。

7. 合并排序算法的基本思想是 将待排序的元素分成大小大致相等的2个子

集合,分别对两个子集合排序,最终将排好序的子集合合并成为所

要求的集合。

7. 最优装载问题可用贪心算法求解。采用 重量最轻者 先装的贪心

选择策略,可产生最优装载问题的最优解。

8.贪心算法和动态规划算法都要求问题具有 最优子结构 性质。这是两类算法的一个

共同点。

9. 动态规划算法通常以自底向上的方式解各子问题,而贪心算法则

通常以 自顶向下 的方式进行,以迭代的方式做出相继的贪心)

()()log ()()(log )1(3222n o n o n n o n o n o o <<<<<

选择,每做出一次贪心选择就将所求问题简化为规模更小的子问题。计算机的资源,最重要的是时间和空间资源。因而,算法的复杂性有时间、空间之分。

10.算法的时间复杂性函数用T(n)表示,它是的函数。

11.f(n)=O(g(n))表示当且仅当存在正的常数C和N0,使得对于所有的n>=N o,有f(n)

12.写出下列f(n)的渐进性态:

f(n)=C0,为常数:f(n)=O(1)

f(n)=3n+2:f(n)=O(n)

f(n)=6*2n+n:f(n)=O(2n)

13.贪心方法是一种求最优解方法。它首先根据题意,选取一种度量标准。然后按这种度量标准对这N个输入排序,并按序一次选入一个量。如果这个输入量的加入,不满足约束条件,则不把此输入加到这部分解中。选择能产生问题最优解的度量标准是使用贪心法设计求解的核心问题。

14.最优子结构性质:。

15.子问题重叠性质:。

16.背包问题可以获得最优解的输入排序是按价值密度排序。

二选择题

1.直接或间接的调用自身的算法称为A。

A递归算法B贪心算法

C迭代算法D动态规划算法

2.阶乘函数用递归定义

P u b l i c s t a t i c i n t f a c t o r i a l(i n t n)

{

i f(n==0)r e t u r n1;

r e t u r n B;

}

A n*f a c t o r i a l(n)

B n*f a c t o r i a l(n-1)

C n*f a c t o r i a l(n-2)

D n*f a c t o r i a l(n+1)

3.与分治法不同的是,适合于用动态规划求解的问题,

D

A经分解得到子问题往往是任意的

B经分解得到子问题往往是互相独立的

C经分解得到子问题往往是互相交叉的

D经分解得到子问题往往不是互相独立的

4.合并排序法的基本思想是:将待排序元素分成大小大致相同的 C

个子集合,分别对每个子集合进行排序,最终将排好序的子集合合并成为所要求的排好序的集合。

A 4

B 3

C 2

D 5

5.二分搜索算法的基本思想是将n个元素分成个数大致相同的两半,取a[n/2]与x进行比较:如果(C),则只要在数组a的右半部继续搜索x。

A x<a[n/2]

B x=a[n/2]

C x>a[n/2]

D x>=a[n/2]

6.当问题的规模n趋向无穷大时,B的数量级(阶)称为算法的渐进时间复杂度。

A空间复杂度B时间复杂度

C冗余度D迭代次数

7.实现快速排序算法如下:

p r i v a t e s t a t i c v o i d q u i c k S o r t(i n t p,i n t r)

{

i f(p

{

i n t q=p a r t i t i o n(p,r); //以确定的基准元素a[p]对

//子数组a[p;r]进行划分

A//对左半段排序

q u i c k S o r t(q+1,r);//对右半段排序

}

}

A q u i c k S o r t(p,q-1)

B q u i c k S o r t(p+1,q-1)

C q u i c k S o r t(p,q+1)

D q u i c k S o r t(p,q-2)

8.计算机算法指的是 C

A.计算方法

B. 排序方法

C.解决问题的方法和过程

D.调度方法

9.在动态规划算法中,问题的最优子结构性质使我们能够以D 的方式递归地从子问题的最优解逐步构造出整个问题的最优解。

A自左向右B自右向左

C自上向下D自底向上

10.用贪心法解最优装载问题的时候,我们采用的贪心选择的策

略是C

A重量大者先装B总价值大的先装

C重量轻者先装D单位价值大的先装

三、判断题

1.从分治法的一般设计模式可以看出,用它设计出的程序一般是一个递归过程。因此,分治法的计算效率通常可以用递归方程来进行分析。(对)

2.对同一个问题,动态规划算法和分治算法的计算复杂性是一样的。(错)

3.0-1背包问题与背包问题这两类问题都可以用贪心算法求解。(错)

4.分治法的基本思想是将一个规模较大的问题分解成若干个规模较小的子问题,这些子问题之间并不一定相互独立。(错)

5.通常用T(n)来表示某一算法的“时间复杂性”,当输入量n逐渐增大时,时间复杂性的

相关文档
最新文档