“数据结构”作业 02 - 解答.doc

上传人:hw****26 文档编号:3788359 上传时间:2019-07-16 格式:DOC 页数:3 大小:36KB
下载 相关 举报
“数据结构”作业 02 - 解答.doc_第1页
第1页 / 共3页
“数据结构”作业 02 - 解答.doc_第2页
第2页 / 共3页
“数据结构”作业 02 - 解答.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

1、2-1 编写一个实现在顺序表中删除给定元素操作的函数:bool deletion(sqList while(inext!=NULL if(hp-next=NULL) return false; / 表中不存在元素 ap=new linknode;p-data=b; p-next=hp-next;hp-next=p;return true;2-3 若要求在时间复杂度为 O(1)的前提下实现线性表访问当前元素的前趋和后继,线性表可以采用哪些存储结构?1. 采用顺序表。设当前元素为 L.datap,则其前趋为 L.datap-1,后继为L.datap+1。2. 采用双向循环链表。设指针 p 指向当前

2、元素,则 p-prior 指向前趋,p-next 指向后继。2-4 比较线性表的顺序存储结构和链式存储结构。线性表顺序存储结构的优点是随机存取,缺点是需预分配一个大数组而存在空间冗余,或分配不足易发生溢出,且元素的插入或删除操作需要移动大量元素而费时,尤其在元素结点较大时更不可取。链式存储结构弥补了顺序存储结构的缺陷,但无法进行随机存取,通常需要通过遍历(由头结点开始)实现定位和查找等操作。2-5* 运用单向循环链表求解约瑟夫环问题,试编程实现输出出列序列。#include typedefstruct node int number;struct node *next;linknode;voi

3、d main() linknode *R, *p, *q;int n, k, m, i;coutn; / n 个人coutk; / 第 k 个开始coutm; / 报数到 m/* 初始化单向循环单链表 */i=1;R=new link_node; / 建立第一个结点R-number=i;i+;p=R;while(inumber=i;i+;p-next=q;p=q;p-next=R; / 使最后一个结点的后继为第一个结点/*/* 定位到编号为 k 的结点 */i=1; p=R;while(inext;i+;/*/while(p-next!=p) / 环中有 1 个以上结点时 i=1;while(inext;i+;coutnumbernext=p-next;delete p;p=q-next;coutnumberendl; / 最后一个出列delete p;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 实用文档资料库 > 策划方案

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。