码迷,mamicode.com
首页 > 编程语言 > 详细

009实现一个算法来删除单链表中的一个结点,仅仅给出指向那个结点的指针(keep it up)

时间:2017-06-15 10:32:42      阅读:137      评论:0      收藏:0      [点我收藏+]

标签:++i   turn   pause   int   break   pos   name   false   use   

呵呵,这个题不能直接删除已知的结点。由于是单链表,不知道前驱,仅仅知道
后继结点,直接删除会使链表断开。只是我们能够删除已知结点的后继结点,

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

#include <iostream>

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;
}


009实现一个算法来删除单链表中的一个结点,仅仅给出指向那个结点的指针(keep it up)

标签:++i   turn   pause   int   break   pos   name   false   use   

原文地址:http://www.cnblogs.com/zhchoutai/p/7015682.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!