设为首页 加入收藏

TOP

009实现一个算法来删除单链表中的一个结点,只给出指向那个结点的指针(keep it up)
2015-07-20 17:52:03 来源: 作者: 【 】 浏览:1
Tags:009 实现 一个 算法 删除 单链表 一个结点 给出 指向 那个 结点 指针 keep
呵呵,这个题不能直接删除已知的结点,因为是单链表,不知道前驱,只知道
后继结点,直接删除会使链表断开。不过我们可以删除已知结点的后继结点,

把后继结点的值赋值给已知结点。

#include 
  
   

struct Node
{
	int   data;
	Node* next;
};

bool removeNode(Node* vNode)
{
	if (vNode == NULL || vNode->next == NULL) return false;
	Node* pNext = vNode->next;
	vNode->data = pNext->data;
	vNode->next = pNext->next;
	delete pNext;
	pNext = NULL;
}

void initList(Node* vRoot)
{
	if (vRoot == NULL) 
	{
		std::cout << "wrong node\n";
		return ;
	}

	for (int i=0; i<20; ++i)
	{
		Node* Temp = new Node;
		Temp->data = i + 1;
		Temp->next = vRoot->next;
		vRoot->next = Temp;
	}
}

int main()
{
	Node* Root = new Node;
	Root->next = NULL;

	initList(Root);

	while (Root->next)//最后一个结点没有删除
	{
		if (!removeNode(Root)) break;
	}

	std::cout << Root->data << std::endl;
	delete Root;
	Root = NULL;

	system("pause");
	return 0;
}
  


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇hdu 4965 Fast Matrix Calculatio.. 下一篇hdu 4961 Boring Sum(高效)

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: