数据结构课后习题及解析第一章

合集下载

数据结构第一章课后习题与答案

数据结构第一章课后习题与答案

第 1 章 绪 论(2005-07-14) -第 1 章 绪 论课后习题讲解1. 填空⑴( )是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。

【解答】数据元素⑵( )是数据的最小单位,( )是讨论数据结构时涉及的最小数据单位。

【解答】数据项,数据元素【分析】数据结构指的是数据元素以及数据元素之间的关系。

⑶ 从逻辑关系上讲,数据结构主要分为( )、( )、( )和( )。

【解答】集合,线性结构,树结构,图结构⑷ 数据的存储结构主要有( )和( )两种基本方法,不论哪种存储结构,都要存储两方面的内容:( )和()。

【解答】顺序存储结构,链接存储结构,数据元素,数据元素之间的关系⑸ 算法具有五个特性,分别是( )、( )、( )、( )、( )。

【解答】有零个或多个输入,有一个或多个输出,有穷性,确定性,可行性⑹ 算法的描述方法通常有( )、( )、( )和( )四种,其中,( )被称为算法语言。

【解答】自然语言,程序设计语言,流程图,伪代码,伪代码⑺ 在一般情况下,一个算法的时间复杂度是( )的函数。

【解答】问题规模⑻ 设待处理问题的规模为n,若一个算法的时间复杂度为一个常数,则表示成数量级的形式为( ),若为n*log25n,则表示成数量级的形式为( )。

【解答】Ο(1),Ο(nlog2n)【分析】用大O记号表示算法的时间复杂度,需要将低次幂去掉,将最高次幂的系数去掉。

2. 选择题⑴ 顺序存储结构中数据元素之间的逻辑关系是由( )表示的,链接存储结构中的数据元素之间的逻辑关系是由( )表示的。

A 线性结构B 非线性结构C 存储位置D 指针【解答】C,D【分析】顺序存储结构就是用一维数组存储数据结构中的数据元素,其逻辑关系由存储位置(即元素在数组中的下标)表示;链接存储结构中一个数据元素对应链表中的一个结点,元素之间的逻辑关系由结点中的指针表示。

⑵ 假设有如下遗产继承规则:丈夫和妻子可以相互继承遗产;子女可以继承父亲或母亲的遗产;子女间不能相互继承。

《数据结构基础教程》习题及解答

《数据结构基础教程》习题及解答

《数据结构基础教程》习题及解答数据结构基础教程习题及解答第一章:数据结构简介1.1 什么是数据结构?数据结构是指相互之间存在一种或多种特定关系的数据元素的集合,包括数据的逻辑结构、物理结构和数据元素之间的运算。

1.2 数据的逻辑结构有哪些?数据的逻辑结构包括线性结构、树形结构和图状结构。

1.3 数据的物理结构有哪些?数据的物理结构包括顺序存储结构和链式存储结构。

1.4 数据结构的主要目标是什么?数据结构的主要目标是提高数据的存储效率和运算效率。

第二章:线性表2.1 线性表的定义线性表是由n(≥0)个数据元素组成的有限序列。

线性表是一种常见的数据结构,常用的实现方式包括数组和链表。

2.2 线性表的顺序存储结构线性表的顺序存储结构是将线性表中的元素存储在连续的存储空间中,通过元素在内存中的物理位置来表示元素之间的关系。

2.3 线性表的链式存储结构线性表的链式存储结构是通过指针将线性表中的元素连接在一起,每个元素包括数据域和指针域。

2.4 线性表的基本操作包括初始化线性表、插入元素、删除元素、查找元素等。

第三章:栈与队列3.1 栈的定义与特性栈是一种具有后进先出特性的线性表,只允许在一端进行插入和删除操作,被称为栈顶。

3.2 栈的顺序存储结构和链式存储结构栈的顺序存储结构和链式存储结构与线性表的存储结构类似,不同之处在于栈只允许在一端进行插入和删除操作。

3.3 栈的应用栈在表达式求值、函数调用和递归等场景中有广泛应用。

3.4 队列的定义与特性队列是一种具有先进先出特性的线性表,允许在一端插入元素,在另一端删除元素。

3.5 队列的顺序存储结构和链式存储结构队列的顺序存储结构和链式存储结构与线性表的存储结构类似,不同之处在于队列允许在一端插入元素,在另一端删除元素。

3.6 队列的应用队列在模拟排队系统、操作系统进程调度等场景中有广泛应用。

第四章:树与二叉树4.1 树的基本概念树是由n(≥0)个节点组成的有限集合,其中有一个称为根节点,除了根节点之外的其余节点被分为m(m≥0)个互不相交的集合,每个集合本身又是一棵树。

【课后习题及答案】严蔚敏-数据结构课后习题及答案解析

【课后习题及答案】严蔚敏-数据结构课后习题及答案解析

6.算 法 的 五 个 重 要 特 性 是 _______、_______、______、_______、_______。 7.数据结构的三要素是指______、_______和________。 8.链式存储结构与顺序存储结构相比较,主要优点是 ________________________________。 9.设有一批数据元素,为了最快的存储某元素,数据结构宜用_________ 结构,为了方便插入一个元素,数据结构宜用____________结构。
四、算法分析题
for(i=1; i<=n; i++) for(j =1; j <=i ; j++) x=x+1; 分 析 :该 算 法 为 一 个 二 重 循 环 ,执 行 次 数 为 内 、外 循 环 次 数 相 乘 ,但 内 循环次数不固定,与外循环有关,因些,时间频度 T(n)=1+2+3+…+n=n*(n+1)/2 有 1/4≤T(n)/n2≤1,故它的时间复杂度为O(n2), 即T(n)与 n2 数 量级相同。 2、分析下列算法段的时间频度及时间复杂度 for (i=1;i<=n;i++) for (j=1;j<=i;j++) for ( k=1;k<=j;k++) x=i+j-k; 分析算法规律可知时间频度 T(n)=1+(1+2)+(1+2+3)+...+(1+2+3+…+n) 由于有 1/6 ≤ T(n)/ n3 ≤1,故时间复杂度为O(n3)
精品课程
课后习题答案数据结构-严来自敏 课后习题及答案解析第一章 绪论

数据结构课后习题及解析第一章

数据结构课后习题及解析第一章

数据结构课后习题及解析第一章第一章数据结构课后习题及解析数据结构是计算机科学中的重要基础知识,对于理解和解决实际问题起着关键的作用。

课后习题是巩固学习效果、帮助理解和掌握数据结构概念的重要途径。

本文将针对数据结构第一章的课后习题进行解析,帮助读者更好地理解和掌握相关概念和知识。

1. 为什么数据结构和算法是计算机科学的核心?数据结构和算法是计算机科学的核心,主要有以下几个原因:首先,数据结构和算法是解决实际问题的基础。

计算机科学的目标是通过编程实现问题的求解。

而数据结构和算法作为实现的基础,能够帮助我们对问题进行合理的建模和求解。

其次,数据结构和算法对程序性能有着重要影响。

在同一种情况下,采用不同的数据结构和算法实现同一个功能,其性能可能有很大的差异。

熟练掌握数据结构和算法,能够帮助我们选择最优的实现方式,提高程序的性能。

最后,数据结构和算法是计算机科学领域的核心知识。

无论是在学术研究还是工程实践中,数据结构和算法都是必备的知识。

熟练掌握数据结构和算法,对于深入理解计算机科学的理论和方法具有重要意义。

2. 什么是数据结构?数据结构是计算机中存储、组织和管理数据的方式。

它包括数据元素之间的关系、数据操作和存储结构等几个方面。

在数据结构中,数据元素是指存储数据的基本单位,可以是一个整数、一个字符或者一个记录。

数据元素之间的关系包括线性关系(如线性表)、非线性关系(如树和图)等。

数据操作则是指对数据的基本操作,如插入、删除、查找等。

存储结构则是指数据在计算机内存中的存放形式,可以是顺序存储结构或链式存储结构。

3. 请列举常见的数据结构类型。

常见的数据结构类型主要包括以下几种:- 数组:是最简单的数据结构,它由一组元素组成,可以通过索引来访问元素。

- 链表:是一种非连续存储的数据结构,其元素通过指针链接在一起。

- 栈:是一种具有特殊操作规则的线性结构,遵循先进后出的原则。

- 队列:是一种具有特殊操作规则的线性结构,遵循先进先出的原则。

课后题解答第一章

课后题解答第一章

什么是数据结构? 有关数据结构的讨论涉及哪三个方面?【解答】数据结构是指数据以及相互之间的关系。

记为:数据结构= { D, R }。

其中,D是某一数据对象,R是该对象中所有数据成员之间的关系的有限集合。

有关数据结构的讨论一般涉及以下三方面的内容:①数据成员以及它们相互之间的逻辑关系,也称为数据的逻辑结构,简称为数据结构;②数据成员极其关系在计算机存储器内的存储表示,也称为数据的物理结构,简称为存储结构;③施加于该数据结构上的操作。

判断下列叙述的对错。

如果正确,在题前打“√”,否则打“⨯”。

(1) 数据元素是数据的最小单位。

(是基本,数据项中的初等项才是)(2) 数据结构是数据对象与对象中数据元素之间关系的集合。

(3) 数据结构是具有结构的数据对象。

(4) 数据的逻辑结构是指各数据元素之间的逻辑关系,是用户按使用需要建立的。

(5) 算法和程序原则上没有区别,在讨论数据结构时二者是通用的。

【解答】(1) ⨯(2) √(3) ⨯(4) √(5) ⨯判断下列叙述的对错。

如果正确,在题前打“√”,否则打“⨯”。

(1) 所谓数据的逻辑结构是指数据元素之间的逻辑关系。

(2) 同一数据逻辑结构中的所有数据元素都具有相同的特性是指数据元素所包含的数据项的个数都相等。

(但是可以做的操作相同)(3) 数据的逻辑结构与数据元素本身的内容和形式无关。

(4) 数据结构是指相互之间存在一种或多种关系的数据元素的全体。

P3(5) 从逻辑关系上讲,数据结构主要分为两大类:线性结构和非线性结构。

【解答】(1) √(2) ⨯(3) √(4) ⨯(5) √有下列几种用二元组表示的数据结构,试画出它们分别对应的图形表示(当出现多个关系时,对每个关系画出相应的结构图),并指出它们分别属于何种结构。

(1) A = (K, R),其中K = { a1, a2, a3, a4 },R = { }(2) B = (K, R),其中K = { a, b, c, d, e, f, g, h },R = { r },r = {<a,b>, <b,c>, <c,d>, <d,e>, <e,f>, <f,g>, <g,h> }(3) C = (K, R),其中K = { a, b, c, d, e, f, g, h },R = { r },r = {<d,b>, <d,g>, <b,a>, <b,c>, <g,e>, <g,h>, <e,f> }(4) D = (K, R),其中K = {1, 2, 3, 4, 5, 6 },R = { r },r = { (1,2), (2,3), (2,4), (3,4), (3,5), (3,6), (4,5), (4,6) }【解答】(1)(2)(3)(4)指出下列各个算法的功能并计算其时间复杂度(1) int Prime ( int n ) {int i = 2, x = (int ) sqrt ( n ); while ( i <= x ) { if ( n % i == 0 ) break; i++; }if ( i > x ) return 1; else return 0; }(2) int sum1 ( int n ) {int p = 1, s = 0;for ( int i = 1; i <= n ; i++ ){ p *= i ; s += p ; } return s ;}(3) int sum2 ( int n ) {int s = 0;for ( int i = 1; i <= n ; i++ ) {int p = 1;for ( int j = 1; j <= i ; j++ ) p *= j ; s += p ; } return s ; }3 4a 2 a6(4) int fun ( int n ) {int i = 1, s = 1; while ( s < n ) s += ++i ; return i ; }(5) void UseFile ( ifstream& inp , int c[ ] ) {//假定inp 所对应的文件中保存有n 个整数。

数据结构第一章习题及解答

数据结构第一章习题及解答

Chap1一、选择题1. 算法的计算量的大小称为计算的(B )。

A.效率 B. 复杂性 C. 现实性 D. 难度2.计算机算法指的是(1) C,它必须具备(2)B这三个特性。

(1) A.计算方法 B. 排序方法 C. 解决问题的步骤序列D. 调度方法(2) A.可执行性、可移植性、可扩充性 B. 可执行性、确定性、有穷性C. 确定性、有穷性、稳定性D. 易读性、稳定性、安全性3. 下面关于算法说法正确的是( D )。

A.算法最终必须由计算机程序实现B.为解决某问题的算法同为该问题编写的程序含义是相同的C. 算法的可行性(基本运算执行有限次)是指指令不能有二义性D. 以上几个都是错误的4.从逻辑上可以把数据结构分为( C )两大类。

A.动态结构、静态结构 B.顺序结构、链式结构C.线性结构、非线性结构 D.初等结构、构造型结构5.以下数据结构中,哪一个是线性结构( D )?A.广义表 B. 二叉树 C. 稀疏矩阵 D. 串6.在下面的程序段中,对x的赋值语句的频度为( C )FOR i:=1 TO n DOFOR j:=1 TO n DOx:=x+1;A. O(2n) B.O(n) C.O(n2) D.O(log2n)7.程序段 FOR i:=n-1 DOWNTO 1 DOFOR j:=1 TO i DOIF A[j]>A[j+1]THEN A[j]与A[j+1]对换;其中 n为正整数,则最后一行的语句频度在最坏情况下是(C)。

A. O(n)B. O(nlogn)C. O(n3)D. O(n2)8.以下哪个数据结构不是多型数据类型(D)A.栈 B.广义表 C.有向图 D.字符串(始终是字符型的,不会存在其他类型)9.以下数据结构中,(A)是非线性数据结构A.树 B.字符串 C.队 D.栈二、判断题1.健壮的算法不会因非法的输入数据而出现莫名其妙的状态。

( A )2.算法可以用不同的语言描述,如果用C 语言或PASCAL语言等高级语言来描述,则算法实际上就是程序了。

数据结构(大专)第一章习题解答

数据结构(大专)第一章习题解答

数据结构(大专)第一章习题解答第一章绪论1.2 设计二次多项式ax2+bx+c的一种抽象数据类型,假定起名为QUAdratic,该类型的数据部分为三个系数项a、b和c,操作部分为:1.初始化数据成员a、b和c(假定用记录类型Quadratic定义数据成员),每个数据成员的默认值为0。

Qiadratic InitQuadratic(float aa=0, float bb=0, float cc=0);解:Quadratic InitQuadratic(float aa, float bb, float cc){Quadratic q;q·a=aa;q·b=bb;q·c=cc;return q;}2.做两个多项式加法,即使对应的系数相加,并返回相加结果。

解:Quadratic Add(Quadratic q1,Quadratic q2);{Quadratic q;q·a=q1·a+q2·a;q·b=q1·b+q2·b;q·c=q1·c+q2·c;retirn q;}3.据给定x的值计算多项式的值。

float Eval(Quadratic q,float x);解:float Eval(Quadratic q, float x){return(q·a*x*x+q·b*x+q·c);}4.计算方程ax2+bx+c=0的两个实数根,对于有实根、无实根和不是二次方程(即a= =0)这三种情况都要返回不同的整数值,以便调用函数做不同的处理。

int Root(Quadratic q, float& r1, float& r2);解:int Root (Quadratic q, float& r1, float& r2){if(q·a= =0) return –1;float x =q·b*q·b –4*q·a*q·c;if(x﹥=0){r1=(float) (-q·b+sqrt(x))/ (2*q·a);r2=(float) (-q·b-sqrt(x))/ (2*q·a);return 1;}elsereturn 0;}5.按照ax **2+bx+c的格式(x2用x **2表示)输出二次多项式,在输出时在注意去掉系数为0的项,并且当b和c的值为负时,其前不能出现加号。

数据结构第一章课后习题解答

数据结构第一章课后习题解答

《数据结构(C语言)》严蔚敏习题参考答案第一章绪论1.8 分析下列各算法的时间复杂度:(1)void prime(int n){/* 判断n是否是素数 */for (i=2; ((n%i)!=0)&&(i<sqrt(n)); i++);if i>sqrt(n) printf("%d is a prime number", n)else printf("%d is not a prime number", n);}/* prime */最坏情况下O(sqrt(n))(2) float sum1(int n){/* 计算1!+2!+…+n! */p=1; sum1=0;for (i=1; i<=n; ++i){p=p*i; sum1=sum1+p}}/* sum1 */O(n)(3) float sum2(int n){/* 计算1!+2!+…+n! */sum2=0;for (i=1; i<=n; ++i){p=1;for (j=1; j<=i; ++j) p=p*j;sum2=sum2+p;}}/* sum2 */O(n2)(4) void sort(int a[],int n){/* 将数组a中的元素按自小到大的顺序排列 */ for (i=1; i<=n-1; ++i){k=i;for (j=i+1; j<=n; ++j) if (a[j]<a[k]) k=j;if (k<>j) {x=a[i];a[i]=a[k];a[k]=x;}}}/* sort */O(n2)(5)void matrimult(a[m][n],b[n][l],c[m][l],int m,int n,int l){ /* a为m×n阶的矩阵,b为n×l阶的矩阵,c为m×l阶的矩阵 */ /* 计算c=a*b */for (i=1; i<=m; ++i)for (j=1; j<=l; ++j)c[i,j]=0;for (i=1; i<=m; ++i)for (j=1; j<=l; ++j)for (k=1; k<=n; ++k)c[i,j]=c[i,j]+a[i,k]*b[k,i];}/* matrimult */O(n3)1.16void print_descending(int x,int y,int z)//按从大到小顺序输出三个数{scanf("%d,%d,%d",&x,&y,&z);if(x<y) x<->y; //<->为表示交换的双目运算符,以下同if(y<z) y<->z;if(x<y) x<->y; //冒泡排序printf("%d %d %d",x,y,z);}//print_descending1.17Status fib(int k,int m,int &f)//求k阶斐波那契序列的第m项的值f{int tempd;if(k<2||m<0) return ERROR;if(m<k-1) f=0;else if (m==k-1) f=1;else{for(i=0;i<=k-2;i++) temp[i]=0;temp[k-1]=1; //初始化for(i=k;i<=m;i++) //求出序列第k至第m个元素的值{sum=0;for(j=i-k;j<i;j++) sum+=temp[j];temp[i]=sum;}f=temp[m];}return OK;}//fib分析:通过保存已经计算出来的结果,此方法的时间复杂度仅为O(m^2).如果采用递归编程(大多数人都会首先想到递归方法),则时间复杂度将高达O(k^m).1.18typedef struct{char *sport;enum{male,female} gender;char schoolname; //校名为'A','B','C','D'或'E'char *result;int score;} resulttype;typedef struct{int malescore;int femalescore;int totalscore;} scoretype;void summary(resulttype result[ ])//求各校的男女总分和团体总分,假设结果已经储存在result[ ]数组中{scoretype score;i=0;while(result[i].sport!=NULL){switch(result[i].schoolname){case 'A':score[ 0 ].totalscore+=result[i].score;if(result[i].gender==0)score[ 0 ].malescore+=result[i].score;else score[ 0 ].femalescore+=result[i].score;break;case 'B':score .totalscore+=result[i].score;if(result[i].gender==0)score .malescore+=result[i].score;else score .femalescore+=result[i].score;break;………………}i++;}for(i=0;i<5;i++){printf("School %d:\n",i);printf("Total score ofmale:%d\n",score[i].malescore);printf("Total score offemale:%d\n",score[i].femalescore);printf("Total score ofall:%d\n\n",score[i].totalscore);}}//summary1.19Status algo119(int a[ARRSIZE])//求i!*2^i序列的值且不超过maxint{last=1;for(i=1;i<=ARRSIZE;i++){a[i-1]=last*2*i;if((a[i-1]/last)!=(2*i)) reurn OVERFLOW;last=a[i-1];return OK;}}//algo119分析:当某一项的结果超过了maxint时,它除以前面一项的商会发生异常.1.20void polyvalue(){float ad;float *p=a;printf("Input number of terms:");scanf("%d",&n);printf("Input the %d coefficients from a0 to a%d:\n",n,n);for(i=0;i<=n;i++) scanf("%f",p++);printf("Input value of x:");scanf("%f",&x);p=a;xp=1;sum=0; //xp用于存放x的i次方for(i=0;i<=n;i++){sum+=xp*(*p++);xp*=x;}printf("Value is:%f",sum);}//polyvalue。

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

第一章习题
一、问答题
1.什么是数据结构?
2.叙述四类基本数据结构的名称与含义。

3.叙述算法的定义与特性。

4.叙述算法的时间复杂度。

5.叙述数据类型的概念。

6.叙述线性结构与非线性结构的差别。

7.叙述面向对象程序设计语言的特点。

8.在面向对象程序设计中,类的作用是什么?
9.叙述参数传递的主要方式及特点。

10.叙述抽象数据类型的概念。

二、判断题(在各题后填写“√”或“×”)
1.线性结构只能用顺序结构来存放,非线性结构只能用非顺序结构来存放。

()
2.算法就是程序。

()
3.在高级语言(如C或 PASCAL)中,指针类型是原子类型。

()
三、计算下列程序段中X=X+1的语句频度
for(i=1;i<=n;i++)
for(j=1;j<=i;j++)
for(k=1;k<=j;k++)
x=x+1;
四、试编写算法,求一元多项式P
n (x)=a
+a
1
x+a
2
x2+a
3
x3+…a
n
x n的值P
n
(x
),并确定算法中的每
一语句的执行次数和整个算法的时间复杂度,要求时间复杂度尽可能小,规定算法中不能使用
求幂函数。

注意:本题中的输入a
i (i=0,1,…,n),x和n,输出为P
n
(x
)。

通常算法的输入和输
出可采用下列两种方式之一:
(1)通过参数表中的参数显式传递。

(2)通过全局变量隐式传递。

试讨论这两种方法的优缺点,并在本题算法中以你认为较好的一种方式实现输入和输出。

实习题
设计实现抽象数据类型“有理数”。

基本操作包括有理数的加法、减法、乘法、除法,以及求有理数的分子、分母。

第一章答案
1.3计算下列程序中x=x+1的语句频度
for(i=1;i<=n;i++)
for(j=1;j<=i;j++)
for(k=1;k<=j;k++)
x=x+1;
【解答】x=x+1的语句频度为:
T(n)=1+(1+2)+(1+2+3)+……+(1+2+……+n)=n(n+1)(n+2)/6
1.4试编写算法,求p n(x)=a0+a1x+a2x2+…….+a n x n的值p n(x0),并确定算法中每一语句的执
行次数和整个算法的时间复杂度,要求时间复杂度尽可能小,规定算法中不能使用求幂函数。

注意:本题中的输入为a i(i=0,1,…n)、x和n,输出为P n(x0)。

算法的输入和输出采用下列方法(1)通过参数表中的参数显式传递(2)通过全局变量隐式传递。

讨论两种方法的优缺点,并在算法中以你认为较好的一种实现输入输出。

【解答】
(1)通过参数表中的参数显式传递
优点:当没有调用函数时,不占用内存,调用结束后形参被释放,实参维持,函数通用性强,移置性强。

缺点:形参须与实参对应,且返回值数量有限。

(2)通过全局变量隐式传递
优点:减少实参与形参的个数,从而减少内存空间以及传递数据时的时间消耗
缺点:函数通用性降低,移植性差
算法如下:通过全局变量隐式传递参数
PolyValue()
{ int i,n;
float x,a[],p;
printf(“\nn=”);
scanf(“%f”,&n);
printf(“\nx=”);
scanf(“%f”,&x);
for(i=0;i<n;i++)
scanf(“%f ”,&a[i]);/*执行次数:n次*/ p=a[0];
for(i=1;i<=n;i++)
{ p=p+a[i]*x; /*执行次数:n次*/
x=x*x;}
printf(“%f”,p);
}
算法的时间复杂度:T(n)=O(n)
通过参数表中的参数显式传递
float PolyValue(float a[ ], float x, int n) {
float p,s;
int i;
p=x;
s=a[0];
for(i=1;i<=n;i++)
{s=s+a[i]*p; /*执行次数:n次*/
p=p*x;}
return(p);
}
算法的时间复杂度:T(n)=O(n)
提示:
第1章绪论
习题
一、问答题
1.什么是数据结构?
2.四类基本数据结构的名称与含义。

3.算法的定义与特性。

4.算法的时间复杂度。

5.数据类型的概念。

6.线性结构与非线性结构的差别。

7.面向对象程序设计语言的特点。

8.在面向对象程序设计中,类的作用是什么?
9.参数传递的主要方式及特点。

10.抽象数据类型的概念。

二、判断题
1.线性结构只能用顺序结构来存放,非线性结构只能用非顺序结构来
存放。

2.算法就是程序。

3.在高级语言(如C、或PASCAL)中,指针类型是原子类型。

三、计算下列程序段中X=X+1的语句频度
for(i=1;i<=n;i++)
for(j=1;j<=i;j++)
for(k=1;k<=j;k++)
x=x+1;
[提示]:
i=1时:1 = (1+1)×1/2 = (1+12)/2
i=2时:1+2 = (1+2)×2/2 = (2+22)/2
i=3时:1+2+3 = (1+3)×3/2 = (3+32)/2

i=n时:1+2+3+……+n = (1+n)×n/2 = (n+n2)/2
f(n) = [ (1+2+3+……+n) + (12 + 22 + 32 + …… + n2 ) ] / 2
=[ (1+n)n/2 + n(n+1)(2n+1)/6 ] / 2
=n(n+1)(n+2)/6
=n3/6+n2/2+n/3
区分语句频度和算法复杂度:
O(f(n)) = O(n3)
四、试编写算法求一元多项式Pn(x)=a0+a1x+a2x2+a3x3+…a n x n的值P n(x0),并确定算法中的每一语句的执行次数和整个算法的时间复杂度,要求时间复杂度尽可能的小,规定算法中不能使用求幂函数。

注意:本题中的输入a i(i=0,1,…,n), x和n,输出为P n(x0).通常算法的输入和输出可采用下列两种方式之一:
(1)通过参数表中的参数显式传递;
(2)通过全局变量隐式传递。

试讨论这两种方法的优缺点,并在本题算法中以你认为较好的一种方式实现输入和输出。

[提示]:float PolyValue(float a[ ], float x, int n) {……}
核心语句:
p=1; (x的零次幂)
s=0;
i从0到n循环
s=s+a[i]*p;
p=p*x;
或:
p=x; (x的一次幂)
s=a[0];
i从1到n循环
s=s+a[i]*p;
p=p*x;
实习题
设计实现抽象数据类型“有理数”。

基本操作包括有理数的加法、减法、乘法、除法,以及求有理数的分子、分母。

相关文档
最新文档