一步一步写算法(之循环单向链表) (二)

2014-11-23 23:33:48 · 作者: · 浏览: 16
;

LINK_NODE* prev = NULL;

if(NULL == ppLinkNode || NULL == *ppLinkNode)

return FALSE;

pIndex = find_data(*ppLinkNode, data);

if(NULL == pIndex)

return FALSE;

if(pIndex == *ppLinkNode){

if(pIndex == pIndex->next){

*ppLinkNode = NULL;

}else{

prev = pIndex->next;

while(pIndex != prev->next)

prev = prev->next;

prev->next = pIndex->next;

*ppLinkNode = pIndex->next;

}

}else{

prev = pIndex->next;

while(pIndex != prev->next)

prev = prev->next;

prev->next = pIndex->next;

}

free(pIndex);

return TRUE;

}和添加数据一样,删除数据也要在两个方面做出改变:

a)如果当前链表节点中只剩下一个数据的时候,删除后需要设置为NULL

b)删除数据的时候首先需要当前数据的前一个数据,这个时候就可以从当前删除的数据开始进行遍历

c) 删除的时候需要重点判断删除的数据是不是链表的头结点数据