唐策善数据结构答案-用C语言描述原版..doc

唐策善数据结构答案-用C语言描述原版..doc

  1. 1、本文档共29页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
唐策善数据结构答案-用C语言描述原版.

第二章 线性表(参考答案) ? 2.1 头指针:指向链表的指针。因为对链表的所有操均需从头指针开始,即头指针具有标识链表的作用,所以链表的名字往往用头指针来标识。如:链表的头指针是la,往往简称为“链表la”。 头结点:为了链表操作统一,在链表第一元素结点(称为首元结点,或首结点)之前增加的一个结点,该结点称为头结点,其数据域不无实际意义(当然,也可以存储链表长度,这只是副产品),其指针域指向头结点。这样在插入和删除中头结点不变。 开始结点:即上面所讲第一个元素的结点。 2.2 只设尾指针的单循环链表,从尾指针出发能访问链表上的任何结点。 2·3 设线性表存放在向量A[]的前elenum个分量中,且递增有序。协议算法将X插入适当位置、 void insert(ElemType A[],int elenum,ElemType x) // 向量A目前有elenum个元素,且递增有序,本算法将x插入到向量A中,并保持向量的递增有序。 { int i=0,j; while (ielenum A[i]=x) i++; // 查找插入位置 for (j= elenum-1;j=i;j--) A[j+1]=A[j];// 向后移动元素 A[i]=x; // 插入元素 } // 算法结束 ? 2·4 void rightrotate(ElemType A[],int n,k) // 以向量作存储结构,本算法将向量中的n个元素循环右移k位,且只用一个辅助空间。 { int num=0; // 计数,最终应等于n int start=0; // 记录开始位置(下标) while (numn) { temp=A[start]; //暂存起点元素值,temp与向量中元素类型相同 empty=start; //保存空位置下标 next=(start-K+n) %n; // 计算下一右移元素的下标 while (next !=start) { A[empty]=A[next];// 右移 num++; // 右移元素数加1 empty=next; next=(next-K+n) %n; // 计算新右移元素的下标 } A[empty]=temp; // 把一轮右移中最后一个元素放到合适位置 num++; start++; // 起点增1,若numn则开始下一轮右移。 } } // 算法结束 2·5 void insert(linklist *L,ElemType x) // 带头结点的单链表L递增有序,本算法将x插入到链表中,并保持链表的递增有序。 { linklist *p=L-next, *pre=L,*s; // p为工作指针,指向当前元素,pre为前驱指针,指向当前元素的前驱 s=(linklist *)malloc(sizeof(linklist));//申请空间,不判断溢出 s-data=x; while (p p-data=x) {pre=p; p=p-next;} // 查找插入位置 pre-next=s; s-next=p; // 插入元素 } // 算法结束 ? 2·6 void invert(linklist *L) // 本算法将带头结点的单链表L逆置。 //算法思想是先将头结点从表上摘下,然后从第一个元素结点开始,依次前插入以L为头结点的链表中。 { linklist *p=L-next,*s; // p为工作指针,指向当前元素,s为p的后继指针 L-next=null;//头结点摘下,指针域置空。算法中头指针L始终不变 while (p) {s=p-next; // 保留后继结点的指针 p-next=L-next; // 逆置 L-next=p; p=s; // 将p指向下个待逆置结点 } } // 算法结束 ? 2·7 (1) int length1(linklist *L) // 本算法计算带头结点的单链表L的长度 { linklist *p=L-next; int i=0; // p为工作指针,指向当前元素,i 表示链表的长度 while (p) { i++; p=p-next; } return(i); } // 算法结束 (2) int length1(node sa[MAXSIZE]) // 本算法计算静态链表s中元素的个数。 { int p=sa[0].next, i=0; // p为工作指针,指向当前元素,

文档评论(0)

sdgr + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档