将X插入在位置P并返回true。若空间已满,则打印“FULL”并返回false;如果参数P指向非法位置,则打印“ILLEGAL POSITION”并返回false;
bool Insert( List L, ElementType X, Position P )
{
if(!L)return false; //1
if(L->Last==MAXSIZE){ //2
printf("FULL");return false; //3
} if(P<0||P>L->Last){ //4
printf("ILLEGAL POSITION");return false; //5
}
for(int i=L->Last;i>P;i--){ //6
L->Data[i]=L->Data[i-1]; //7
}L->Data[P]=X; //8
++L->Last; //9
return true; //10
}
第6行到第9行:++L->Last不懂是什么意思。理解不了这段代码的功能
void Insert_Linklist(LinkList& p,int pos,char e){
if(pos<=0||Get_Length(p)<pos-1)return; //1
int cnt=2; //2
LinkList head=p->next,t; //3
while(head!=p){ //4
if(cnt==pos){ //5
t=(LinkList)malloc(sizeof(LNode)); //6
t->data=e; //7
t->next=head->next; //8
head->next=t; //9
}
cnt++; //10
head=head->next; //11
}
第4行到第9行:t=(LinkList)malloc(sizeof(LNode))这段代码有什么用途。
原文:https://www.cnblogs.com/JianDa/p/10597344.html