首页 > 其他 > 详细

线性表总结

时间:2019-03-29 00:10:07      阅读:203      评论:0      收藏:0      [点我收藏+]

1.代码段1简介:删除顺序表的重复元素
代码1:

void DelSameNode(List &L) //1
{ //2
if(L->length==0) //3
return ; //4
int a[L->length]; //5
int i=0,j,k,flag; //6
for(j=L->length-1;j>0;j--) //7
{ //8
flag=0; //9
for(k=j-1;k>=0;k--) //10
{ //11
if(L->data[j]==L->data[k]) //12
flag=1; //13
} //14
if(flag==0) //15
{ //16
a[i]=L->data[j]; //17
i++; //18
} //19
} //20
j=0; //21
a[i]=L->data[0]; //22
L->length=i+1; //23
while(i>=0) //24
{ //25
L->data[j++]=a[i--]; //26
} //27
} //28

不懂的地方:23->28行,不清楚功能是如何实现

对代码的分析:该代码是用于删除线性表中的重复元素,首先判断链表L是否为空,为空表则无需进行删除操作;若链表L中有若干相应元素,定义一个新的数组用来存储删除的数
据, i,j,k用于循环,flag用于判断数字是否重复。第一个for循环(7->20)用于把删除后的数字赋值到数组a[]中,flag=0表示不为重复数据,flag=1则表示重复数
据,不能被存储在删除后的链表中。然后更新数组的长度(23:L->length=i+1; ),while循环(24->27)作用为反向输入数组,保证L->data中的数据顺序正确

2.代码段2简介:有序链表的合并
代码2:

List Merge( List L1, List L2 ) { //1
List pa, pb, pc, L; //2
L = new LNode; //3
pa = L1->Next; //4
pb = L2->Next; //5
pc = L; //6
while ( pa && pb ) { //7
if ( pa->Data <= pb->Data ) { //8
pc->Next = pa; //9
pc = pa; //10
pa = pa->Next; //11
} //12
else { //13
pc->Next = pb; //14
pc = pb; //15
pb = pb->Next; //16
} //17
} //18
pc->Next = pa ? pa : pb; //19
L1->Next = NULL; //20
L2->Next = NULL; //21
return L; //22
} //23

不懂的地方:7->16,不清楚语法;19->21,不清楚功能如何实现

对代码的分析:首先申请了一个头结点L,指针pa指向L1的第一个结点,指针pb指向L2的第一个结点,指针pc指向上面创建的头结点L。当L1,L2链表还没有遍历完成的时候,如果pa
的数据比较小,就将pa串进L中,把pc移向当前最后一个结点pa,也是尾插。然后在L1的链表中,更新pa的位置。如果L1未遍历完,将L1全部串入L,如果L2未遍历
完,将L2全部串入L

线性表总结

原文:https://www.cnblogs.com/ggad/p/10618565.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!