数据结构与算法习题库重点.docx
- 文档编号:1704646
- 上传时间:2022-10-23
- 格式:DOCX
- 页数:29
- 大小:169.24KB
数据结构与算法习题库重点.docx
《数据结构与算法习题库重点.docx》由会员分享,可在线阅读,更多相关《数据结构与算法习题库重点.docx(29页珍藏版)》请在冰豆网上搜索。
数据结构与算法习题库重点
第一章绪论
一.选择题
1.数据结构被形式地定义为(K,R),其中K是①_B_的有限集合,R是K上的②_D_的有限集合。
①A.算法B.数据元素C.数据操作D.逻辑结构②A.操作B.映象C.存储D.关系
2.算法分析的目的是①C,算法分析的两个主要方面是②A。
①A.找出数据结构的合理性
B.研究算法中的输入和输出的关系
C.分析算法的效率以求改进
D.分析算法的易懂性和文档性
②A.空间复杂性和时间复杂性
B.正确性和简明性
C.可读性和文档性
D.数据复杂性和程序复杂性
3.在计算机存储器内表示时,物理地址和逻辑地址相同并且是连续的,称之为
(B)
A.逻辑结构B.顺序存储结构
C.链表存储结构D.以上都不对
4.数据结构中,在逻辑上可以把数据结构分成:
(C)。
A.动态结构和静态结构B.紧凑结构和非紧凑结构
C.线性结构和非线性结构D.内部结构和外部结构
5.以下属于顺序存储结构优点的是(A)。
A.存储密度大B.插入运算方便
C.删除运算方便D.可方便地用于各种逻辑结构的存储表示
6.数据结构研究的内容是(D)。
A.数据的逻辑结构B.数据的存储结构
C.建立在相应逻辑结构和存储结构上的算法D.包括以上三个方面
7.链式存储的存储结构所占存储空间(A)。
A.分两部分,一部分存放结点值,另一部分存放表示结点间关系的指针
B.只有一部分,存放结点值
C.只有一部分,存储表示结点间关系的指针
D.分两部分,一部分存放结点值,另一部分存放结点所占单元数
8.一个正确的算法应该具有5个特性,除输入、输出特性外,另外3个特性是(A)。
A.确定性、可行性、有穷性B.易读性、确定性、有效性
C.有穷性、稳定性、确定性D.可行性、易读性、有穷性
9.以下关于数据的逻辑结构的叙述中正确的是(A)。
A.数据的逻辑结构是数据间关系的描述
B.数据的逻辑结构反映了数据在计算机中的存储方式
C.数据的逻辑结构分为顺序结构和链式结构
D.数据的逻辑结构分为静态结构和动态结构
10.算法分析的主要任务是(C)。
A.探讨算法的正确性和可读性B.探讨数据组织方式的合理性
C.为给定问题寻找一种性能良好的解决方案D.研究数据之间的逻辑关系
二.解答
设有一数据的逻辑结构为:
B=(D,S),其中:
D={d1,d2,…,d9}
S={
第二章线性表
一、选择题
1.下述哪一条是顺序存储结构的优点?
(A)
A.存储密度大B.插入运算方便C.删除运算方便D.可方便地用于各种逻辑结构的存储表示
2.下面关于线性表的叙述中,错误的是哪一个?
(B)
A.线性表采用顺序存储,必须占用一片连续的存储单元。
B.线性表采用顺序存储,便于进行插入和删除操作。
C.线性表采用链接存储,不必占用一片连续的存储单元。
D.线性表采用链接存储,便于插入和删除操作。
3.若某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算,则利用(A)存储方式最节省时间。
A.顺序表B.双链表C.带头结点的双循环链表D.单循环链表
4.某线性表中最常用的操作是在最后一个元素之后插入一个元素和删除第一个元素,则采用(D)存储方式最节省运算时间。
A.单链表B.仅有头指针的单循环链表C.双链表D.仅有尾指针的单循环链表
5.在一个长度为n的顺序表中删除第i个元素(0<=i<=n)时,需向前移动(A)个元素
A.n-iB.n-i+lC.n-i-1D.i
6.从一个具有n个结点的单链表中查找其值等于x的结点时,在查找成功的情况下,需平均比较(C)个元素结点
A.n/2B.nC.(n+1)/2D.(n-1)/2
7.设单链表中指针p指向结点m,若要删除m之后的结点(若存在),则需修改指针的操作为(A)
A.p->next=p->next->next;B.p=p->next;
C.p=p->next->next;D.p->next=p;
8.在一个单链表中,已知q结点是p结点的前趋结点,若在q和p之间插入s结点,则须执行(B)
A.s->next=p->next;p->next=s
B.q->next=s;s->next=p
C.p->next=s->next;s->next=p
D.p->next=s;s->next=q
9.线性表的顺序存储结构是一种(A)的存储结构。
A.随机存取B.顺序存取C.索引存取D.散列存取
二、填空
1.在线性表的顺序存储中,元素之间的逻辑关系是通过性表的链接存储中,元素之间的逻辑关系是通过指针决定的。
2.在双向链表中,每个结点含有两个指针域,一个指向直接前驱结点,另一个指向直接后继结点。
3.当对一个线性表经常进行存取操作,而很少进行插入和删除操作时,则采用_顺序存储结构为宜。
相反,当经常进行的是插入和删除操作时,则采用链式存储结构为宜。
三、算法设计
1.设有一个正整数序列组成的有序单链表(按递增次序有序,且允许有相等的整数存在),试编写能实现下列功能的算法(要求用最少的时间和最小的空间)
①确定在序列中比正整数x大的数有几个(相同的数只计算一次)
②将单链表中比正整数x小的偶数从单链表中删除
intcount(Linklisth,intx)
{
intnum=0;
Linknode*p;
p=h->next;
while(p&&p->data<=x)//p指针向后移动,直至p指向第一个值大于x的结点
p=p->next;
while(p)
if(p->next&&p->data==p->next->data)
//若p没有指向链表中同一数值的最后一个结点,则向后移动
p=p->next;
else
//若p指向数值相同的结点中的最后一个,则num加1,p指针后移,继续执行while循环{
num++;
p=p->next;
}
returnnum;
}
②
voiddelevenl(Linklist&h,intx)
{
Linknode*p,*r;
p=h->next;r=h;
while(p&&p->data { if(p->data%2==0) { r->next=p->next; free(p); p=r->next; } else { r=p; p=p->next; } } } 2.设有一个表头指针为h的单链表。 试设计一个算法,通过遍历一趟链表,将链表中所有结点的链接方向逆转,如下图所示。 要求逆转结果链表的表头指针h指向原链表的最后一个结点。 2.voidconverse(Linklist&h) { Linknode*p,*q; p=h->next; h->next=NULL; q=p->next; while(q) { p->next=h; h=p; p=q; q=q->next; } p->next=h; h=p; } p Λ3.设计算法将一个带头结点的单链表A分解为两个具有相同结构的链表B、C,其中B表的结点为A表中值小于零的结点,而C表的结点为A表中值大于零的结点(链表A的元素类型为整型,要求B、C表利用A表的结点)。 3.voiddecompose(LinklistLa,Linklist&Lb,Linklist&Lc) { Linknode*p; Lc=(Linknode*)malloc(sizeof(Linknode)); Lc->next=NULL; p=La->next; Lb=La; Lb->next=NULL; while(p) { La=p->next; if(p->data>0) { p->next=Lc->next; Lc->next=p; }}}else{p->next=Lb->next;Lb->next=p;}p=La; 4.假设链表A、B分别表示一个集合,试设计算法以判断集合A是否是集合B的子集,若是,则返回1,否则返回0,并分析算法的时间复杂度。 4.intsubset(LinkListla,LinkListlb) {LinkNode*pa,*pb; pa=la->next; while(pa) {pb=lb->next; while(pb&&(pb->data! =pa->data))pb=pb->next; if(! pb)return0; pa=pa->next; } return1; }算法时间复杂度O(A.Length*B.Length) 5.设有一单循环链表la,其结点有三个域: prior、data与next,其中data为数据域,,next域指向直接后继,prior域应指向直接前驱,但目前空着。 试写一算法将此单循环链表改造为双向循环链表。 5.voidpriorset(DuLinkList&la) {p=la;q=la->next; while(q! =la){q->prior=p;p=q;q=q->next;} q->prior=p; } 第三章栈和队列 一、选择题 1.已知栈的最大容量为4。 若进栈序列为1,2,3,4,5,6,且进栈和出栈可以穿插进行,则可能出现的出栈序列为(C) A.5,4,3,2,1,6B.2,3,5,6,1,4 C.3,2,5,4,1,6D.1,4,6,5,2,3 设有一个栈,元素的进栈次序为A,B,C,D,E,下列是不可能的出栈序列(C) A.A,B,C,D,EB.B,C,D,E,A C.E,A,B,C,DD.E,D,C,B,A 2.在一个具有n个单元的顺序栈中,假定以地址低端(即0单元)作为栈底, 以top作为栈顶指针,当做出栈处理时,top变化为(C) A.top不变B.top=0C.top--D.top++ 3.向一个栈顶指针为hs的链栈中插入一个s结点时,应执行(B) A.hs->next=s; B.s->next=hs;hs=s; C.s->next=hs->next;hs->next=s; D.s->next=hs;hs=hs->next; 4.在具有n个单元的顺序存储的循环队列中,假定front和rear分别为队头指针和队尾指针,则判断队满的条件为(D) A.rear%n==frontB.(front+l)%n==rear C.rear%n-1==frontD.(rear+l)%n==front 5.在具有n个单元的顺序存储的循环队列中,假定front和rear分别为队头指针和队尾指针,则判断队空的条件为(C) A.rear%n==frontB.front+l=rear C.rear==frontD.(rear+l)%n=front 6.在一个链队列中,假定front和rear分别为队首和队尾指针,则删除一个结点的操作为(A) A.front=front->nextB.rear=rear->next C.rear=front->nextD.front=rear->next 7.某堆栈的输入序列为1,2,3,…,n,输
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 算法 习题 重点