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