《软件技术基础》复习思考题.ppt
《《软件技术基础》复习思考题.ppt》由会员分享,可在线阅读,更多相关《《软件技术基础》复习思考题.ppt(126页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、软件技术基础复习思软件技术基础复习思考题考题目录目录第第1章章 导论导论第第2章章 程序设计语言程序设计语言 第第3章章 算法与数据结构算法与数据结构第第4章章 操作系统操作系统第第5章章 关系数据库系统关系数据库系统第第6章章 软件工程软件工程软件技术基础电子教案2 一、名词解释一、名词解释一、名词解释一、名词解释数据,数据元素,逻辑结构,存储结构,线性结构,非线数据,数据元素,逻辑结构,存储结构,线性结构,非线性结构,顺序存储结构,链式存储结构,索引存储结构,散列性结构,顺序存储结构,链式存储结构,索引存储结构,散列存储结构,算法,时间复杂度存储结构,算法,时间复杂度二、填空题二、填空题二
2、、填空题二、填空题1 1从某种意义上说,数据、数据元素和数据项反映了数从某种意义上说,数据、数据元素和数据项反映了数据组织的三个层次,数据可由若干个据组织的三个层次,数据可由若干个_构成,数据元素构成,数据元素可由若干个可由若干个_构成。构成。2 2从逻辑关系上讲,数据结构主要分为两大类,它们是从逻辑关系上讲,数据结构主要分为两大类,它们是_和和_。第第3章章 算法与数据结构算法与数据结构(一一)33 3把逻辑上相邻的数据元素存储在物理上相邻的存储单把逻辑上相邻的数据元素存储在物理上相邻的存储单元中的存储结构是元中的存储结构是_。4 4通常从通常从_、_、_等几方面评价等几方面评价算法的质量。
3、算法的质量。5 5常见时间复杂性的量级有:常数阶常见时间复杂性的量级有:常数阶O(_)O(_)、对数阶、对数阶O(_)O(_)、线性阶、线性阶O(_)O(_)、平方阶、平方阶O(_)O(_)和指数阶和指数阶O(_)O(_)。6 6在一般情况下,一个算法的时间复杂性是在一般情况下,一个算法的时间复杂性是_的的函数。函数。7 7一个算法的时空性能是指该算法的一个算法的时空性能是指该算法的_和和_,前者是算法包含的,前者是算法包含的_,后者是算法需要的,后者是算法需要的_。4 三、问答题三、问答题三、问答题三、问答题分析下列程序段的时间复杂度。分析下列程序段的时间复杂度。(1)i=1;k=0;(1)
4、i=1;k=0;while(in)while(in)k=k+10*i;i+;k=k+10*i;i+;(2)i=1;j=0;(2)i=1;j=0;while(i+j=n)while(i+jj)j+;if(ij)j+;else i+;else i+;5线性表线性表 一、名词解释一、名词解释一、名词解释一、名词解释线性结构,非线性结构,顺序存储结构,链式存储结构,线性结构,非线性结构,顺序存储结构,链式存储结构,存储密度存储密度二、填空题二、填空题二、填空题二、填空题1 1为了便于讨论,有时将含为了便于讨论,有时将含n(n0)n(n0)个结点的线性结构表示个结点的线性结构表示成成(a(a1 1,a
5、a2 2,,a an n),其中每个,其中每个a ai i代表一个代表一个_。a a1 1称为称为_结点,结点,a an n称为称为_结点,结点,i i称为称为ai ai在线性表中的在线性表中的_。对。对于任意一对相邻结点于任意一对相邻结点a ai i、a ai+1i+1(1in),(1in),a ai i称为称为a ai+1i+1的直接的直接_,a ai+1i+1称为称为a ai i的直接的直接_。第第3章章 算法与数据结构算法与数据结构(二二)6 2 2线性结构的基本特征是:若至少含有一个结点,则除线性结构的基本特征是:若至少含有一个结点,则除开始结点没有直接开始结点没有直接_外,其他结点
6、有且仅有一个直接外,其他结点有且仅有一个直接_;除终端结点没有直接;除终端结点没有直接_外,其它结点有且仅有一外,其它结点有且仅有一个直接个直接_。3 3线性表的逻辑结构是线性表的逻辑结构是_结构。其所含结点的个数结构。其所含结点的个数称为线性表的称为线性表的_,简称,简称_。4 4表长为表长为0 0的线性表称为的线性表称为_。5 5顺序表的特点是顺序表的特点是_。6 6假定顺序表的每个假定顺序表的每个datatypedatatype类型的结点占用类型的结点占用k(k1)k(k1)个内个内存单元,存单元,b b是顺序表的第一个存储结点的第一个单元的内存地是顺序表的第一个存储结点的第一个单元的内
7、存地址,那么第址,那么第i i个结点个结点a ai i的存储地址为的存储地址为_。7 7 7以下为顺序表的删除运算,分析算法,请在以下为顺序表的删除运算,分析算法,请在_处填处填上正确的语句。上正确的语句。void delete_sqlist(sqlist*L,int i)/void delete_sqlist(sqlist*L,int i)/删除顺序表删除顺序表L L中的第中的第i-1i-1个个位置上的结点位置上的结点 if(iL-last)error(“if(iL-last)error(“非法位置非法位置”)”);for(j=i+1;j=L-last;j+)_;for(j=i+1;j=L-
8、last;j+)_;L-last=L-last-1;L-last=L-last-1;8 8为了便于实现各种运算,通常在单链表的第一个结点为了便于实现各种运算,通常在单链表的第一个结点之前增设一个类型相同的结点,称为之前增设一个类型相同的结点,称为_,其它结点称为,其它结点称为_。8 9 9以下是求带头结点的单链表长度的运算,分析算法,请以下是求带头结点的单链表长度的运算,分析算法,请在在_处填上正确的语句。处填上正确的语句。int length_linklist(linklist*head)/int length_linklist(linklist*head)/求表求表headhead的长度的
9、长度 _;_;j=0;j=0;while(p-next!=NULL)while(p-next!=NULL)_;_;j+;j+;return(j);/return(j);/返回表长度返回表长度 91010以下为带头结点的单链表的定位运算,分析算法,请以下为带头结点的单链表的定位运算,分析算法,请在在_处填上正确的语句。处填上正确的语句。int locate_lklist(lklist head,datatype x)int locate_lklist(lklist head,datatype x)/求表求表headhead中第一个值等于中第一个值等于x x的结点的序号。不存在这种结的结点的序号。
10、不存在这种结点时结果为点时结果为0 0 p=head-next;j=0;p=head-next;j=0;while(_)p=p-while(_)p=p-next;j+;next;j+;if(p-data=x)return(j);if(p-data=x)return(j);else return(0);else return(0);101111循环链表与单链表的区别仅仅在于其终端结点的指针循环链表与单链表的区别仅仅在于其终端结点的指针域值不是域值不是_,而是一个指向,而是一个指向_的指针。的指针。11三、选择题三、选择题三、选择题三、选择题1 1线性结构中的一个结点代表一个线性结构中的一个结点代
11、表一个()()。A.A.数据元素数据元素 B.B.数据项数据项 C.C.数据数据 D.D.数据结构数据结构2 2对于顺序表,以下说法错误的是对于顺序表,以下说法错误的是()()。A.A.顺序表是用一维数组实现的线性表,数组的下标可以顺序表是用一维数组实现的线性表,数组的下标可以看成是元素的绝对地址看成是元素的绝对地址 B.B.顺序表的所有存储结点按相应数据元素间的逻辑关系顺序表的所有存储结点按相应数据元素间的逻辑关系决定的次序依次排列决定的次序依次排列C.C.顺序表的特点是:逻辑结构中相邻的结点在存储结构顺序表的特点是:逻辑结构中相邻的结点在存储结构中仍相邻中仍相邻D.D.顺序表的特点是:逻辑
12、上相邻的元素存储在物理位置顺序表的特点是:逻辑上相邻的元素存储在物理位置也相邻的单元中也相邻的单元中123 3对顺序表上的插入、删除算法的时间复杂性分析来说,对顺序表上的插入、删除算法的时间复杂性分析来说,通常以通常以()()为标准操作。为标准操作。A.A.条件判断条件判断 B.B.结点移动结点移动 C.C.算术表达式算术表达式 D.D.赋值语句赋值语句4 4对于顺序表的优缺点,以下说法错误的是对于顺序表的优缺点,以下说法错误的是()()。A.A.无需为表示结点间的逻辑关系而增加额外的存储空间无需为表示结点间的逻辑关系而增加额外的存储空间B.B.可以方便地随机存取表中的任一结点可以方便地随机存
13、取表中的任一结点C.C.插入和删除运算较为方便插入和删除运算较为方便D.D.容易造成一部分空间长期闲置而得不到充分利用容易造成一部分空间长期闲置而得不到充分利用135 5在循环链表中,将头指针改设为尾指针在循环链表中,将头指针改设为尾指针(rear)(rear)后,其头后,其头结点和尾结点的存储位置分别是结点和尾结点的存储位置分别是()()。A.realA.real和和rear-next-next rear-next-next B.rear-next B.rear-next 和和realrealC.rear-next-nextC.rear-next-next和和rear rear D.rear
14、D.rear和和rear-nextrear-next6 6设指针设指针P P指向双向链表的某一结点,则双向链表结构指向双向链表的某一结点,则双向链表结构的对称性可用的对称性可用()()来描述。来描述。A.p-prior-next-=p-next-next A.p-prior-next-=p-next-next B.p-prior-prior-=p-next-priorB.p-prior-prior-=p-next-priorC.p-prior-next-=p-next-prior C.p-prior-next-=p-next-prior D.p-next-next=p-prior-priorD
15、.p-next-next=p-prior-prior147 7循环链表的主要优点是循环链表的主要优点是()()。A.A.不再需要头指针不再需要头指针B.B.已知某个结点的位置后,能够容易找到它的直接前趋已知某个结点的位置后,能够容易找到它的直接前趋C.C.在进行插入、删除运算时,能更好地保证链表不断开在进行插入、删除运算时,能更好地保证链表不断开D.D.从表中任一结点出发都能扫描到整个链表从表中任一结点出发都能扫描到整个链表158 8设设rearrear是指向非空带头结点的循环单链表的尾指针,则是指向非空带头结点的循环单链表的尾指针,则删除表首结点的操作可表示为删除表首结点的操作可表示为()(
16、)。A.p=rear;B.rear=rear-next;A.p=rear;B.rear=rear-next;rear=rear-next;free(rear);rear=rear-next;free(rear);free(p)free(p)C.rear=rear-next-next;D.p=rear-next-next;C.rear=rear-next-next;D.p=rear-next-next;free(rear);rear-next-next=p-next;free(rear);rear-next-next=p-next;free(p);free(p);1617下面给出的算法段是要把一
17、个新结点下面给出的算法段是要把一个新结点*q*q作为非空双向链作为非空双向链表中的结点表中的结点*p*p的前驱,插入到此双向链表中。不能正确完成的前驱,插入到此双向链表中。不能正确完成要求的算法段是要求的算法段是()()。A.q-LLink=p-LLink;A.q-LLink=p-LLink;B.p-LLink=q;B.p-LLink=q;q-Rlink=p;q-Rlink=p;q-Rlink=p;q-Rlink=p;p-LLink=q;p-LLink=q;p-LLink-Rlink=q;p-LLink-Rlink=q;p-LLink-Rlink=q;q-LLink=p-LLink;p-LLi
18、nk-Rlink=q;q-LLink=p-LLink;C.q-LLink=p-LLink;C.q-LLink=p-LLink;q-Rlink=p;q-Rlink=p;p-LLink-Rlink=q;p-LLink-Rlink=q;p-LLink=q;p-LLink=q;181010若某线性表中最常用的操作是取第若某线性表中最常用的操作是取第i i个元素和找第个元素和找第i i个个元素的前趋元素,则采用元素的前趋元素,则采用()()存储方式最节省时间。存储方式最节省时间。A.A.顺序表顺序表 B.B.单链表单链表 C.C.双链表双链表 D.D.单循环链表单循环链表19四、算法设计四、算法设计四、
19、算法设计四、算法设计1 1设设A=(aA=(a1 1,a,a2 2,a,a3 3,a,an n)和和B=(bB=(b1 1,b,b2 2,b,bmm)是两个线性表是两个线性表(假假定所含数据元素均为整数定所含数据元素均为整数)。若。若n=mn=m且且a ai i=b=bi i(i=1,n)(i=1,n),则称,则称A=BA=B;若;若a ai i=b=bi i(i=1,j)(i=1,j)且且a aj+1j+1bbj+1j+1(jn=m)(jn=m),则称,则称ABABAB。试编写一个比较。试编写一个比较A A和和B B的算法,当的算法,当ABABAB时,分别输出时,分别输出-1-1,0 0或或
20、1 1。2 2分别以顺序表和单链表作存储结构,各写一个实现线分别以顺序表和单链表作存储结构,各写一个实现线性表的就地性表的就地(即使用尽可能少的附加空间即使用尽可能少的附加空间)逆置的算法,在原表逆置的算法,在原表的存储空间内将线性表的存储空间内将线性表(a(a1 1,a a2 2,a,an n)逆置为逆置为(a(an n,a,a2 2,a,a1 1)。203 3已知单链表已知单链表L L中的结点是按值非递减有序排列的,试中的结点是按值非递减有序排列的,试写一算法,将值为写一算法,将值为x x的结点插入表的结点插入表L L中,使得中,使得L L仍然有序。仍然有序。4 4已知单链表已知单链表L
21、L是一个递增有序表,试编写一高效算法,是一个递增有序表,试编写一高效算法,删除表中值大于删除表中值大于minmin且小于且小于maxmax的结点的结点(若表中有这样的结点若表中有这样的结点),同时释放被删除结点的空间,这里同时释放被删除结点的空间,这里minmin和和maxmax是两个给定的参是两个给定的参数。请分析算法的时间复杂度。数。请分析算法的时间复杂度。5 5设设A A和和B B是两个单链表,表中元素递增有序。试编写一是两个单链表,表中元素递增有序。试编写一个算法,将个算法,将A A和和B B归并成一个按元素值递减有序的单链表归并成一个按元素值递减有序的单链表C C,并要求辅助空间为并
22、要求辅助空间为O(1)O(1),C C表的头结点可另辟空间。请分析算表的头结点可另辟空间。请分析算法的时间复杂度。法的时间复杂度。216 6已知一单链表中的数据元素含有三个字符已知一单链表中的数据元素含有三个字符(即字母字即字母字符、数字字符和其它字符符、数字字符和其它字符)。试编写算法,构造三个循环链表,。试编写算法,构造三个循环链表,使每个循环链表中只含同一类的字符,且利用原表中的结点空使每个循环链表中只含同一类的字符,且利用原表中的结点空间作为这三个表的结点空间间作为这三个表的结点空间(头结点可另辟空间头结点可另辟空间)。7 7已知已知A A、B B和和C C为三个元素值递增有序的线性表
23、,现要为三个元素值递增有序的线性表,现要求对表求对表A A作如下运算:作如下运算:删去那些既在表删去那些既在表B B中出现又在表中出现又在表C C中出中出现的元素。试分别以两种存储结构现的元素。试分别以两种存储结构(顺序结构和链式结构顺序结构和链式结构)编写编写实现上述运算的算法。实现上述运算的算法。8 8假设在长度大于假设在长度大于1 1的循环链表中,既无头结点也无头指的循环链表中,既无头结点也无头指针,针,s s为指向链表中某个结点的指针,试编写算法删除结点为指向链表中某个结点的指针,试编写算法删除结点*s*s的直接前趋结点。的直接前趋结点。22栈和队列栈和队列 一、名词解释一、名词解释一
24、、名词解释一、名词解释栈,顺序栈,链栈,队列,顺序队列,循环列队,链队栈,顺序栈,链栈,队列,顺序队列,循环列队,链队二、填空题二、填空题二、填空题二、填空题1 1栈修改的原则是栈修改的原则是_,因此,栈又称为,因此,栈又称为_线性表。在栈顶进行插入运算,被称为线性表。在栈顶进行插入运算,被称为_,在栈顶进行,在栈顶进行删除运算,被称为删除运算,被称为_。2 2对于顺序栈而言,对于顺序栈而言,top=0top=0表示表示_,此时作退栈运,此时作退栈运算,则产生算,则产生“_”_”;top=stack_maxsize-1top=stack_maxsize-1表示表示_,此时作进栈运算,则产生此时
25、作进栈运算,则产生“_”_”。233 3以下运算实现在顺序栈上的进栈,请在以下运算实现在顺序栈上的进栈,请在_处用适处用适当的语句予以填充。当的语句予以填充。245 5以下运算实现循环队列的初始化,请在以下运算实现循环队列的初始化,请在_处用处用适当句子予以填充。适当句子予以填充。void InitCycQueue(Cycqueue*&sq)void InitCycQueue(Cycqueue*&sq)_;_;_;sq-rear=0;_;sq-rear=0;6 6链队在一定范围内不会出现链队在一定范围内不会出现_的情况。的情况。当当lq-front=lq-rearlq-front=lq-rea
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件技术基础 软件技术 基础 复习 思考题
限制150内