您的位置:首页 > 编程语言 > C语言/C++

C语言常见单链表面试题(1)

2016-05-29 17:22 615 查看
1、删除单链表的非尾节点
解题思路:按照一般的思路单链表删除节点是必须知道其前驱节点才能删除,而在本题中不知道前驱节点,所以转换思路,先将需要删除的节点跟其后继节点的数据域交换,然后再删除既可。
void EraseNotTail(pLinkNode pos)
{
assert(pos);
pLinkNode del = NULL;//删除的节点
del = pos->next;
pos->data = pos->next->data;
pos->next = pos->next->next;
free(del);
del = NULL;
}


2、冒泡排序单链表
void BubbleSort(pList * pHead)
{
pLinkNode cur = *pHead;
pLinkNode end = NULL;
int change = 1;
assert(pHead);
if (*pHead == NULL)
{
return;
}
else if (cur->next == NULL)
{
return;
}
while ((cur != end)&&(change))//控制排序几轮
{
change = 0;
while ((cur)&&(cur->next != end))//排序
{
change = 1;
if (cur->data > cur->next->data)
{
DataType tmp = cur->data;
cur->data = cur->next->data;
cur->next->data = tmp;
}
cur = cur->next;
}
end = cur;
cur = *pHead;//使得单链表从头开始
}
}


3、在当前节点前插入一个数据x
思路解析:按照一般的思路其应该需要找到节点的前驱节点,才能插入,但是可以换一个思路,可以先把节点插入到其后方,然后再将两个节点的数据域进行交换即可很好的解决该问题。
void InsertFrontNode(pLinkNode pos, DataType x)
{
pLinkNode newNode = BuyNode(x);
assert(pos);
newNode->next = pos->next;
pos->next = newNode;
DataType tmp = pos->data;
pos->data = pos->next->data;
pos->next->data = tmp;
}


本文出自 “LeetCode小白的逆袭之路” 博客,请务必保留此出处http://10788311.blog.51cto.com/10778311/1746890
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: