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

C++11 删除链表重复数值

时间:2016-11-26 02:05:46      阅读:121      评论:0      收藏:0      [点我收藏+]

标签:include   复数   ptr   div   链表   out   cout   namespace   rem   

#include <memory>
#include <iostream>
#include <chrono>
#include <thread>
using namespace std;

struct ListNode{
	int val;
	shared_ptr<ListNode> next;
};

bool InsertNode(shared_ptr<ListNode>& insertPos,int val)
{
	shared_ptr<ListNode> node(new ListNode);
	if (!node)
		return false;
	node->val = val;
	node->next = NULL;
	insertPos->next = node;
	insertPos = node;

	return true;
}

bool  InitLinkList(shared_ptr<ListNode>& head)
{
	if ( (!head) || NULL != head->next )
		return false;

	head->val = 1;
	shared_ptr<ListNode> tail = head;

	InsertNode(tail, 1);
	InsertNode(tail, 2);
	InsertNode(tail, 3);
	InsertNode(tail, 3);


	return true;
}

void CoutLinkList(const shared_ptr<ListNode>& head)
{
	for (shared_ptr<ListNode> node = head;
		node; node = node->next)
	{
		cout << node->val << " ";
	}
	cout << endl;
}

shared_ptr<ListNode>  removeDuplicates(shared_ptr<ListNode>& head)
{
	if (head == NULL)
	{
		return NULL;
	}

	shared_ptr<ListNode> node = head;
	while(node->next != NULL){
		if(node->val == node->next->val){
			shared_ptr<ListNode> tmp = node->next;
			node->next = node->next->next;
		}else
		{
			node = node->next;
		}
	}
	return head;
}




int main()
{
	shared_ptr<ListNode> head(new ListNode);
	InitLinkList(head);

	CoutLinkList(head);

	head = removeDuplicates(head);

	CoutLinkList(head);

    return 0;
}

  

C++11 删除链表重复数值

标签:include   复数   ptr   div   链表   out   cout   namespace   rem   

原文地址:http://www.cnblogs.com/itdef/p/6103187.html

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