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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值