- 7
- 0
- 约8.94千字
- 约 28页
- 2017-03-26 发布于贵州
- 举报
ds02_线性表02_顺序存储ds02_线性表02_顺序存储
千头万绪该如何说起?以客户端程序代码为引导,观察其所得结果并实证源代码,是一个良好的学习路径。 例:项目vectorTest 顺序表基本操作 在顺序表存储结构中,很容易实现线性表的一些操作,如线性表的构造、第i个元素的访问。 需掌握的基本操作 InitList_Sq ListInsert_Sq ListDelete_Sq LocateElem_Sq MergeList_Sq 注意:C语言中的数组下标从“0”开始 顺序表基本操作的实现--InitList_Sq 思路:初始化SqList的三个成员 列举法分析 列举法分析移动次数和i的关系 i 移动次数 1 n = n-1+1 2 n-1 = n-2+1 3 n-2 = n-3+1 ... ... n 1 = n-n+1 i n -i+1 顺序表的按值查找---时间复杂度分析 基本操作:两个结点之间的比较 1、若存在和e相同结点ai,比较次数为i( 1≤i≤ L.length ) 2、否则为L.length 所以,时间复杂度为O(L.length) 试写一算法,实现顺序表的就地逆置,即利用原表的存储空间将线性表(a1,a2,…,an)逆置为(an,an-1,…,a1) void Reverse(int *array, int length); 设将n(n1)个整数存放到一维数组R中。设计一个算法,将R中的序列循环左移P(0Pn)个位置,即将R中的数据由{X0, X1,......Xn-1}变换为{Xp, Xp+1,...Xn-1,X0, X1,...Xp-1}。(09考研) void RotateRight(int *array, int bitcount); // 循环右移bitcount位 可直接利用上个题目的实现 参考集合并运算(算法2.7),实现集合的交运算(Intersection)。(选做) 顺序表的插入 顺序表的插入运算是指在表的第i(1=i=n+1)个位置之前插入一个新结点e,使长度为n的顺序表 (a1,…a i-1,ai,…,an) 变成长度为n+1的线性表 (a1,…a i-1,e,ai,…,an) 顺序表的插入 33 例:(35,12,24,42),在i=2的位置之前插入33。 4 35 12 24 42 a1 a2 a3 a4 0 1 2 3 4 42 24 12 33 5 Q:什么时候不能插入? 注意边界条件 1. 合理的插入位置:1≤i≤L.length+1(i指的是元素的序号) 2. 表满:L.length=L.listsize L.length L.elem 顺序表的插入 算法伪码 1. 如果元素的插入位置不合理,则返回错误信息; 2. 如果表已满,则增加分配; 3. 将最后一个元素至第i个元素分别向前移动一个位置; 4. 将元素x填入位置i处; 5. 表长加1。 线性表的插入 P24 void ListInsert (SqList L, int i, ElemType e) { //第i个位置之前插入e,初始条件:顺序线性表L已存在,1≤i≤ListLength(L)+1 ElemType *newbase, *q, *p; if (i1 || iL.length+1) return ERROR; // i值不合法 if (L.length = L.listsize) // 当前存储空间已满, 增加分配 { newbase = (ElemType *)realloc(L.elem, (L.listsize+LISTINCREMENT)*sizeof(ElemType)); if (!newbase) { free(L.elem); exit(OVERFLOW);} // 存储分配失败 L.elem = newbase; // 赋值为新基址,因为新基址有可能改变 L.listsize += LIST_INCREMENT; // 增加存储容量 } q = (L.elem[i-1]); // q为插入位置, 等同于q = L.elem + i - 1; for (p=L.elem+L.length-1; p=q; - -p) // 插入位置及之后的元素右移 *(p+1) = *p; *q = e; // 插入e ++L.leng
您可能关注的文档
- cpk培训教材---new.ppt
- consonants 辅音音标.ppt
- cpd第二学期第一次课——礼仪.ppt
- cpu卡燃气表功能介绍.doc
- consonants(辅音).ppt
- creo_3.0_f000中文版图文安装教程及下载地址.doc
- city‘weather english.ppt
- cssci(2014-2015)来源期刊拟收录目录(共533种).doc
- compressed air quality, measurement & achievement.ppt
- ct机的组成与维修.doc
- 广东省广州省实验中学教育集团2025-2026学年八年级上学期期中考试物理试题(解析版).docx
- 广东省广州大学附属中学2025-2026学年八年级上学期奥班期中物理试题(解析版).docx
- 广东省广州市第八十六中学2025-2026学年八年级上学期期中物理试题(含答案).docx
- 广东省广州市第八十九中学2025-2026学年八年级上学期期中考试物理试题(解析版).docx
- 广东省广州市第二中学2025-2026学年八年级上学期期中考试物理试题(含答案).docx
- 广东省广州市第八十六中学2025-2026学年八年级上学期期中物理试题(解析版).docx
- 广东省广州市第八十九中学2025-2026学年八年级上学期期中考试物理试题(含答案).docx
- 广东省广州市第二中学2025-2026学年八年级上学期期中考试物理试题(解析版).docx
- 2026《中国人寿上海分公司营销员培训体系优化研究》18000字.docx
- 《生物探究性实验教学》中小学教师资格模拟试题.docx
原创力文档

文档评论(0)