中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

單鏈表的相關問題

發布時間:2020-07-25 15:11:46 來源:網絡 閱讀:238 作者:yayaru9240 欄目:編程語言
#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)//約瑟夫環問題
	{
		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)//找兩個已排好序鏈表的相同數
	{
		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() //查找鏈表的中間節點
	{
		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)//刪除倒數第Pos個節點
	{
		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) //控制排序次數
		{
			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();
//}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

昌宁县| 寻甸| 临邑县| 陆良县| 寿光市| 上思县| 富锦市| 华宁县| 平顺县| 庆阳市| 张北县| 清流县| 改则县| 兰坪| 普陀区| 安乡县| 北辰区| 安泽县| 华蓥市| 宁明县| 重庆市| 宁乡县| 贵州省| 河源市| 建瓯市| 尤溪县| 五原县| 玛曲县| 兴业县| 文成县| 赤峰市| 海南省| 土默特右旗| 中西区| 邹城市| 九台市| 陆川县| 朔州市| 蕲春县| 兴和县| 新沂市|