1数据结构(本)形成性考核作业册使用说明本作业册是中央广播电视大学计算机科与技术专业(本科)数据结构(本)课程形成性考核的依据,与《数据结构(本科)》教材(李伟生主编,中央电大出版社出版)配套使用。数据结构(本)课程是中央广播电视大学计算机科学技术专业的一门统设必修、学位课程,4学分,共72学时。其中实验24学时,开设一学期。本课程的特点是综合性、实践性强,内容抽象,在专业中具有承上启下的作用。因此,在学习本课程时,要注意理论联系实际,结合教学内容进行上机实践,认真完成作业和实验内容。本课程的总成绩按百分制记分,其中形成性考核所占的比例为30%,终结性考试占70%(闭卷,答题时限为90分钟)。课程总成绩达到60分及以上者为合格,可以获得该课程的学分。本课程的学位课程学分为70分,即课程总成绩达到70分及以上者有资格申请专业学位。本课程共设计了4次形考作业,每次形考作业均包括实验内容,由各地电大根据学生对作业中各种题型练习和实验的完成情况进行考核。对于实验内容要求按实验要求认真完成,并提交实验报告。2数据结构(本)课程作业作业1(本部分作业覆盖教材第1-2章的内容)一、单项选择题1.在数据结构中,从逻辑上可以把数据结构分为()。A.动态结构和静态结构B.紧凑结构和非紧凑结构C.线性结构和非线性结构D.内部结构和外部机构2.下列说法中,不正确的是()。A.数据元素是数据的基本单位B.数据项是数据中不可分割的最小可标识单位C.数据可有若干个数据元素构成D.数据项可由若干个数据元素构成3.一个存储结点存储一个()。A.数据项B.数据元素C.数据结构D.数据类型4.每个存储结点只存储一个数据元素,各结点存储在连续的存储空间,该存储方式是()存储方式。A.顺序B.链接C.索引D.散列5.每个存储结点不仅含有一个数据元素,还包含一组指针,该存储方式是()存储方式。A.顺序B.链接C.索引D.散列6.数据结构中,与所使用的计算机无关的是数据的()。A.存储结构B.物理结构C.逻辑结构D.物理和存储结构7.下列的叙述中,不属于算法特性的是()。A.有穷性B.输入性C.可行性D.可读性8.算法分析的目的是()。A.找出数据结构的合理性B.研究算法中的输入和输出的关系C.分析算法的效率以求改进D.分析算法的易懂性和文档性9.数据结构是一门研究计算机中()对象及其关系的科学。A.数值运算B.非数值运算C.集合D.非集合10.算法的时间复杂度与()有关。A.所使用的计算机B.与计算机的操作系统3C.与算法本身D.与数据结构11.把数据存储到计算机中,并具体体现数据元素间的逻辑结构称为()。A.逻辑结构B.物理结构C.算法的具体实现D.给相关变量分配存储单元12.设有一个长度为n的顺序表,要在第i个元素之前(也就是插入元素作为新表的第i个元素),则移动元素个数为()。A.n-i+1B.n-iC.n-i-1D.i13.设有一个长度为n的顺序表,要删除第i个元素移动元素的个数为()。A.n-i+1B.n-iC.n-i-1D.i14.在一个单链表中,p、q分别指向表中两个相邻的结点,且q所指结点是p所指结点的直接后继,现要删除q所指结点,可用语句()。A.p=q-nextB.p-next=qC.p-next=qnextD.q-next=NULL15.在一个单链表中p所指结点之后插入一个s所指的结点时,可执行()。A.p-next=s;snext=pnextB.p-next=snext;C.p=s-nextD.s-next=p-next;p-next=s;16.非空的单向循环链表的尾结点满足()(设头指针为head,指针p指向尾结点)。A..P-next==NULLB.P==NULLC.P-next==headD.P==head17.链表不具有的特点是()。A.可随机访问任一元素B.插入删除不需要移动元素C.不必事先估计存储空间D.所需空间与线性表长度成正比18.带头结点的链表为空的判断条件是()(设头指针为head)。A.head==NULLB.head-next==NULLC.head-next==headD.head!=NULL19.在一个单链表中,p、q分别指向表中两个相邻的结点,且q所指结点是p所指结点的直接后继,现要删除q所指结点,可用语句()。A.p=q-nextB.p-next=qC.p-next=q-nextD.q-next=NULL20.下面关于线性表的叙述错误的是()。A..线性表采用顺序存储,必须占用一片地址连续的单元B.线性表采用顺序存储,便于进行插入和删除操作C.线性表采用链式存储,不必占用一片地址连续的单元D.线性表采用链式存储,便于进行插入和删除操作21.在一个链队中,假设f和r分别为队头和队尾指针,则删除一个结点的运算为()。A.r=f-next;B.r=r-next;C.f=f-next;D.f=r-next;22.在一个链队中,假设f和r分别为队头和队尾指针,则插入s所指结点的运算为()。A.f-next=s;f=s;B.r-next=s;r=s;C.s-next=r;r=s;D.s-next=f;f=s;23.一个顺序表第一个元素的存储地址是90,每个元素的长度为2,则第6个元素的地址4是()。A.98B.100C.102D.10624.用链表表示线性表的优点是()。A.便于随机存取B.花费的存储空间较顺序存储少C.便于插入和删除D.数据元素的物理顺序和逻辑顺序相同25.有关线性表的正确说法是()。A.每个元素都有一个直接前驱和一个直接后继B.线性表至少要求一个元素C.表中的元素必须按由小到大或由大到下排序D.除了一个和最后一个元素外,其余元素都有一个且仅有一个直接前驱和一个直接后继二、填空题1.在一个长度为n的顺序存储结构的线性表中,向第i(1in+1)个元素之前插入新元素时,需向后移动个数据元素。2.从长度为n的采用顺序存储结构的线性表中删除第i(1in+1)个元素,需向前移动个元素。3.数据结构按结点间的关系,可分为4种逻辑结构:、、、。4.数据的逻辑结构在计算机中的表示称为或。5.除了第1个和最后一个结点外,其余结点有且只有一个前驱结点和后继结点的数据结构为,每个结点可有任意多个前驱和后继结点数的结构为。6.算法的5个重要特性是、、、、。7.数据结构中的数据元素存在多对多的关系称为________结构。8.数据结构中的数据元素存在一对多的关系称为________结构。9.数据结构中的数据元素存在一对一的关系称为________结构。10.要求在n个数据元素中找其中值最大的元素,设基本操作为元素间的比较。则比较的次数和算法的时间复杂度分别为________和________。11.在一个单链表中p所指结点之后插入一个s所指结点时,应执行________和p-next=s;的操作。12.设有一个头指针为head的单向循环链表,p指向链表中的结点,若p-next==________,则p所指结点为尾结点。13.在一个单向链表中,要删除p所指结点,已知q指向p所指结点的前驱结点。则可以用操作________。14.设有一个头指针为head的单向链表,p指向表中某一个结点,且有p-next==NULL,通过操作________,就可使该单向链表构造成单向循环链表。15.每个结点只包含一个指针域的线性表叫。16.线性表具有和两种存储结构。17.数据的逻辑结构是从逻辑关系上描述数据,它与数据的关系无关,是独立于计算机的。518.在双向循环链表的每个结点中包含指针域,其中next指向它的,prior指向它的,而头结点的prior指向,尾结点的next指向。19.单向循环链表是单向链表的一种扩充,当单向链表带有头结点时,把单向链表中尾结点的指针域由空指针改为;当单向链表不带头结点时,则把单向链表中尾结点的指针域由空指针改为指向。20.线性链表的逻辑关系时通过每个结点指针域中的指针来表示的。其逻辑顺序和物理存储顺序不再一致,而是一种存储结构,又称为。三、问答题1.简述数据的逻辑结构和存储结构的区别与联系,它们如何影响算法的设计与实现?2.解释顺序存储结构和链式存储结构的特点,并比较顺序存储结构和链式存储结构的优缺点。3.什么情况下用顺序表比链表好?4.头指针、头结点、第一个结点(或称首元结点)的区别是什么?65.解释带头结点的单链表和不带头结点的单链表的区别。6.与单链表相比,双向循环链表有哪些优点?四、程序填空题1.下列是用尾插法建立带头结点的且有n个结点的单向链表的算法,请在空格内填上适当的语句。NODE*create1(n)/*对线性表(1,2,.....,n),建立带头结点的单向链表*/{NODE*head,*p,*q;inti;p=(NODE*)malloc(sizeof(NODE));head=p;q=p;p-next=NULL;for(i=1;i=n;i++){p=(NODE*)malloc(sizeof(NODE));(1);(2);7(3);(4);}return(head);}2.下列是用头插法建立带头结点的且有n个结点的单向链表的算法,请在空格内填上适当的语句。NODE*create2(n)/*对线性表(n,n-1,.....,1),建立带头结点的线性链表*/{NODE*head,*p,*q;inti;p=(NODE*)malloc(sizeof(NODE));(1);p-next=NULL;(2);for(i=1;i=n;i++){p=(NODE*)malloc(sizeof(NODE));p-data=i;if(i==1)(3);else(4);(5);}return(head);}3.下列是在具有头结点的单向列表的第ij个结点之间插入新结点x的算法(1in+1),请在空格内填上适当的语句。intinsert(NODE*head,intx,inti){NODE*q,*p;intj;(1);j=0;while((q!=NULL)&&(ji-1)){q=q-next;j++;}if(q==NULL)return(0);p=(NODE*)malloc(sizeof(NODE));p-data=x;8(2);(3);return(1);}4.下列是在具有头结点单向列表中删除第i个结点,请在空格内填上适当的语句。intdelete(NODE*head,inti){NODE*p,*q;intj;q=head;j=0;while((q!=NULL)&&(ji-1))/*找到要删除结点的直接前驱,并使q指向它*/{q=q-next;j++;}if(q==NULL)return(0);(1);(2);free(p);return(1);}五、完成:实验1――线性表根据实验要求(见教材P201-202)认真完成本实验,并提交实验报告。