欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

單鏈表的相關問題

#include<iostream>
using namespace std;
#include<assert.h>
template<class T>
struct Node
{
	int _data;
	Node* _next;
	Node(const T& x)
		:_data(x)
		, _next(NULL)
	{}
};

template<class T>
class PlinkList
{
public:
	PlinkList()
		:_head(NULL)
	{}
	void PushBack(const T& x)
	{
		if (_head == NULL)
		{
			_head = new Node<T>(x);
			_tail = _head;
		}
		else
		{
			Node<T>* tmp = new Node<T>(x);
			Node<T>* cur = _head;
			while (cur->_next)
			{
				cur = cur->_next;
			}
			tmp->_next = cur->_next;
			cur->_next = tmp;
			_tail = tmp;
		}
	}
	Node<T>* JosephusCycle(int k)//約瑟夫環(huán)問題
	{
		assert(_head);
		_tail->_next = _head;
		Node<T>* begin = _head;
		while (1)
		{
			if (begin->_next == begin)
				break;
			int count = k - 1;
			while (count-- > 0)
			{
				//del = begin;
				begin = begin->_next;
			}
			Node<T>* del = begin->_next;
			//swap(begin->_data, begin->_next->_data);
			begin->_next = del->_next;
			begin = begin->_next;
			delete del;
		}
		return begin;
	}
	void Find_comm(Node<T>* one, Node<T>* two)//找兩個已排好序鏈表的相同數(shù)
	{
		assert(one && two);
		Node<T>* cur1 = one;
		Node<T>* cur2 = two;
		while (cur1 && cur2)
		{
			if (cur1->_data > cur2->_data)
				cur2 = cur2->_next;
			else if (cur1->_data < cur2->_data)
				cur1 = cur1->_next;
			else
			{
				cout << cur1->_data << " ";
				cur1 = cur1->_next;
				cur2 = cur2->_next;
			}
		}
		cout << "not comm data" << endl;
	}
	Node<T>* Find_CenterNode() //查找鏈表的中間節(jié)點
	{
		assert(_head);
		Node<T>* slow = _head;
		Node<T>* fast = _head;
		while (fast && fast->_next)
		{
			slow = slow->_next;
			fast = fast->_next->_next;
		}
		return slow;
	}
	bool del_thelast_Knode(int pos)//刪除倒數(shù)第Pos個節(jié)點
	{
		int count = 0;
		Node<T>* cur = _head;
		while (cur)
		{
			cur = cur->_next;
			count++;
		}
		if (pos<0 || pos>count)
			return false;
		if (pos == count)//如果要刪除的為頭結點
		{
			Node<T>* del = _head;
			_head = _head->_next;
			delete del;
			return true;
		}
		/*else //采用快慢指針讓快指針先走pos步,慢指針再走
		{
			Node<T>* slow = _head;
			Node<T>* fast = _head;
			Node<T>* prev = _head;
			int k = 0;
			while (fast)
			{
				if (k >= pos)
				{
					prev = slow;
					slow = slow->_next;
				}
				fast = fast->_next;
				k++;
			}
			Node<T>* del = slow;
			prev->_next = del->_next;
			delete del;
			return true;
		}*/
		else  //也可走count-pos步并記錄該位置的前一個位置
		{
			count = count - pos ;
			int num = 0;
			Node<T>* prev = _head;
			Node<T>* tmp = prev;
			cur = _head;
			while (cur->_next)
			{
				if (num + 1 == count)
				{
					tmp = cur;
					cur = cur->_next;
					break;
				}
				cur = cur->_next;
				//prev = prev->_next;
				num++;
			}
			Node<T>* del = cur;
			tmp->_next = del->_next;
			delete del;
			return true;
		}
	}

	Node<T>* reverse()//逆置單鏈表
	{
		assert(_head);
		if (_head->_next == NULL)
			return _head;
		Node<T>* cur = _head;
		Node<T>* newHead = NULL;
		while (cur)
		{
			Node<T>* tmp = cur;
			cur = cur->_next;
			tmp->_next = newHead;
			newHead = tmp;
		}
		return newHead;
	}
	void PrintTailTohead(Node<T>* head)//從尾到頭打印單鏈表
	{
		if (head == NULL)
			return;
		else
		{
			PrintTailTohead(head->_next);
			cout << head->_data<<"->";
		}
	}
	void Display()
	{
		assert(_head);
		Node<T>* cur = _head;
		while (cur)
		{
			cout << cur->_data << "->";
			cur = cur->_next;
		}
		cout << "NULL" << endl;
	}

	void Bubble_sort()//鏈表的冒泡排序
	{
		assert(_head);
		Node<T>* prev = _head;
		Node<T>* end = NULL;
		while (prev->_next) //控制排序次數(shù)
		{
			Node<T>* tmp = _head;
			while (tmp->_next != end)//相鄰兩元素交換單趟排序
			{
				if (tmp->_data > tmp->_next->_data)
					swap(tmp->_data, tmp->_next->_data);
				tmp = tmp->_next;
			}
			end = tmp;
			prev = prev->_next;
		}
	}
	Node<T>* Quicksort(Node<T>* begin, Node<T>* end)
	{
		Node<T>* prev = begin;
		Node<T>* cur = begin->_next;
		int key = begin->_data;
		while (cur != end)
		{
			if (cur && cur->_data < key)
			{
				prev = prev->_next;
				if (prev->_data != cur->_data)
					swap(prev->_data, cur->_data);
			}
			cur = cur->_next;
		}
		swap(begin->_data, prev->_data);
		return prev;
	}
	void Quick_sort(Node<T>* begin, Node<T>* end)
	{
		if (begin != end)
		{
			Node<T>* tmp = Quicksort(begin, end);
			Quick_sort(begin, tmp);
			Quick_sort(tmp->_next, end);
		}
	}
	~PlinkList()
	{
		if (_head == NULL)
			return;
		Node<T>* cur = _head;
		while (cur)
		{
			Node<T>* del = cur;
			cur = cur->_next;
			delete del;
		}
		_head = NULL;
	}
public:
	Node<T>* _head;
	Node<T>* _tail;
};

//void Test()
//{
//	PlinkList<int> l;
//	l.PushBack(8);
//	l.PushBack(3);
//	l.PushBack(7);
//	l.PushBack(1);
//	l.PushBack(9);
//	l.PushBack(6);
//	l.PushBack(0);
//	l.PushBack(5);
//	//l.Display();
//	//l.Quick_sort(l._head, NULL);
//	//l.Bubble_sort();
//	//l._head=l.reverse();
//	//l.del_thelast_Knode(8);
//	//cout << l.Find_CenterNode()->_data << endl;
//	//l.PrintTailTohead(l._head);
//	//cout << "NULL" << endl;
//	cout<<l.JosephusCycle(3)->_data<<endl;
//	//l.Display();
//}

文章名稱:單鏈表的相關問題
本文網(wǎng)址:http://www.aaarwkj.com/article34/igsope.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設計公司、、品牌網(wǎng)站建設、網(wǎng)站設計公司網(wǎng)站制作、服務器托管

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設
精品久久激情中文字幕| 丰满少妇被激烈的插进去| 97视频免费观看在线| 传媒在线免费观看视频| 美女呻吟被爽到高潮在线| 中文字幕乱码亚洲影视| 国产亚洲一区二区三区乱码| 日本福利资源在线观看| 免费观看日本成人午夜大片 | 亚洲欧美综合精品二区| 亚洲美女国产精选999| 花花草草寻亲记在哪里免费看| 男人的天堂在线观看黄片| 伊人青草免费在线视频| 欧美在线观看黄片视频| 91出品国产福利在线| 九九九热在线观看视频| 欧美日本国产高清不卡| 中文字幕有码av海量| 久久99热最新地址获取| 丝袜美腿亚洲欧美日韩| 大香蕉欧美日韩在线视频| 日本一区二区三区高清不卡| 有码精品视频在线观看| 亚洲无线码一区国产欧美国日| 亚洲一区日韩精品电影| 麻豆黄片在线免费观看| 在线视频天堂亚洲天堂| 一区不卡在线视频免费国产| 无毛亚洲视频在线观看| 日本午夜理论视频在线播放| 国产精品久久久av大片| 国产精品麻豆色哟哟av| 亚洲成人免费电影91| 国产二区三区在线播放| 欧美激情在线精品一区二区| 亚洲天堂日韩欧美在线一区| 国产精品天天影视久久| 中文字幕人妻丝袜二区| 一区二区中文字幕精品| 亚洲黄色大片在线免费观看|