- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
千头万绪该如何说起?以客户端程序代码为引导,观察其所得结果并实证源代码,是一个良好的学习路径。 例:项目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
原创力文档


文档评论(0)