数据结构经典算法试题数据结经典算法试题数据结构经典算法试题数据结构经典算法试题.doc

数据结构经典算法试题数据结经典算法试题数据结构经典算法试题数据结构经典算法试题.doc

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

1. 假设有两个按元素值递增次序排列的线性表,均以单链表形式存储。请编写算法将这两个单链表归并为一个按元素值递减次序排列的单链表,并要求利用原来两个单链表的结点存放归并后的单链表。【北京大学 1998 三、1 (5分)】LinkedList Union(LinkedList la,lb) { pa=la-next; pb=lb-next;   la-next=null;   while(pa!=null pb!=null) 当两链表均不为空时作   if(pa-data=pb-data) { r=pa-next; pa-next=la-next; ∥将pa结点链于结果表中,同时逆置。   la-next=pa;   pa=r;   }   else   {r=pb-next;   pb-next=la-next; 将pb结点链于结果表中,同时逆置。   la-next=pb;   pb=r;   }   while(pa!=null) 将la表的剩余部分链入结果表,并逆置。   {r=pa-next; pa-next=la-next; la-next=pa; pa=r; }   while(pb!=null)   {r=pb-next; pb-next=la-next; la-next=pb; pb=r; } } 1)设有两个无头结点的单链表,头指针分别为ha,hb,链中有数据域data,链域next,两链表的数据都按递增序存放,现要求将hb表归到ha表中,且归并后ha仍递增序,归并中ha表中已有的数据若hb中也有,则hb中的数据不归并到ha中,hb的链表在算法中不允许破坏。【南京理工大学1997 四、3(15分)】LinkedList Union(LinkedList ha, hb) ∥ha和hb是两个无头结点的数据域值递增有序的单链表,本算法将hb中并不出现在ha中的数据合并到ha中,合并中不能破坏hb链表。{LinkedList la;   la=(LinkedList)malloc(sizeof(LNode));   la-next=ha;   pa=ha;   pb=hb;   pre=la;   while(papb)  if(pa-datapb-data)处理ha中数据   {pre-next=pa;pre=pa;pa=pa-next;}   else if(pa-datapb-data)处理hb中数据。   {r=(LinkedList)malloc(sizeof(LNode)); r-data=pb-data; pre-next=r; pre=r; pb=pb-next; } Else ∥处理pa- data=pb-data; {pre-next=pa; pre=pa;   pa=pa-next;两结点数据相等时,只将ha的数据链入。   pb=pb-next;   }   if(pa!=null)pre-next=pa;将两链表中剩余部分链入结果链表。   else pre-next=pb;   free(la);   } 2)已知头指针分别为la和lb 的带头结点的单链表中,结点按元素值非递减有序排列。写出将la 和 lb两链表归并成一个结点按元素值非递减有序排列的单链表(其头指针为 lc),并计算算法的时间复杂度。【燕山大学 1998 五 (20分)】pa=la-next;pb=hb-next; lc=(LinkedList )malloc(sizeof(LNode)); pc=lc; ∥pc是结果链表中当前结点的前驱 while(papb) if(pa-datapb-data)   {pc-next=pa;pc=pa;pa=pa-next;}   else {pc-next=pb;pc=pb;pb=pb-next;}   if(pa)pc-next=pa; else pc-next=pb;   free(la);free(lb);释放原来两链表的头结点。 2. 设带头结点且头指针为ha和hb的两线性表A和B 分别表示两个集合。两表中的元素皆为递增有序。请写一算法求A和B的并集AUB。要求该并集中的元素仍保持递增有序。且要利用A和B的原有结点空间。【北京邮电大学 1992 二 (15分)】Linke

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档