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

C++實(shí)現(xiàn)堆-創(chuàng)新互聯(lián)

#include <iostream>
using namespace std;
#include <vector>
#include <assert.h>

//仿函數(shù)
template<class T>
struct Less
{
	bool operator()(const T& left, const T& right)
	{
		return left < right;
	}
};

template<class T>
struct Greater
{
	bool operator()(const T& left, const T& right)
	{
		return left > right;
	}
};

template<class T, class Compare = Less<T>>//默認(rèn)為小堆
class Heap
{
public:
	Heap()
	{}

	Heap(const T* array, size_t size)
	{
		for (size_t i = 0; i < size; ++i)
		{
			_a.push_back(array[i]);
		}

		for (int i = (_a.size()-2)/2; i >= 0; --i)
		{
			_AdjustDown(i);
		}
	}

	void Push(const T& x)
	{
		_a.push_back(x);

		_AdjustUp(_a.size()-1);
	}

	void Pop()
	{
		assert(!_a.empty());

		swap(_a[0], _a[_a.size()-1]);
		_a.pop_back();
		_AdjustDown(0);
	}

	T& GetTop()
	{
		assert(!_a.empty());

		return _a[0];
	}

	bool Empty()
	{
		return _a.empty();
	}

	size_t Size()
	{
		return _a.size();
	}

	void Print()
	{
		for (size_t i = 0; i < _a.size(); ++i)
		{
			cout<<_a[i]<<" ";
		}
		
		cout<<endl;
	}

protected:
	//向下調(diào)整
	void _AdjustDown(size_t parent)
	{
		Compare compare;
		size_t child = parent*2 + 1;

		while (child < _a.size())
		{
			//比較左右孩子
			if (child+1 < _a.size() 
				&& compare(_a[child+1], _a[child]))
			{
				++child;
			}

			if (compare(_a[child], _a[parent]))
			{
				swap(_a[child], _a[parent]);

				parent = child;
				child = parent*2 + 1;
			}
			else
			{
				break;
			}
		}
	}

	//向上調(diào)整
	void _AdjustUp(size_t child)
	{
		Compare compare;
		size_t parent = (child-1)/2;
		
		while (child > 0)
		{
			if (compare(_a[child], _a[parent]))
			{
				swap(_a[parent], _a[child]);

				child = parent;
				parent = (child-1)/2;
			}
			else
			{
				break;
			}
		}
	}

protected:
	vector<T> _a;
};


void Test()
{
	int a[10] = {10, 11, 13, 12, 16, 18, 15, 17, 14, 19};
	Heap<int, Greater<int>> hp1(a, sizeof(a)/sizeof(a[0]));
	hp1.Print();
	cout<<"size:"<<hp1.Size()<<endl;
	cout<<"top:"<<hp1.GetTop()<<endl;
	cout<<"empty:"<<hp1.Empty()<<endl;
}

int main()
{
	Test();

	return 0;
}

C++實(shí)現(xiàn)堆

目前創(chuàng)新互聯(lián)已為近千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、網(wǎng)站改版維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、岳陽(yáng)縣網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國(guó)云服務(wù)器,動(dòng)態(tài)BGP最優(yōu)骨干路由自動(dòng)選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動(dòng)現(xiàn)已開啟,新人活動(dòng)云服務(wù)器買多久送多久。

名稱欄目:C++實(shí)現(xiàn)堆-創(chuàng)新互聯(lián)
標(biāo)題來源:http://aaarwkj.com/article20/dddijo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、外貿(mào)網(wǎng)站建設(shè)、面包屑導(dǎo)航、外貿(mào)建站、網(wǎng)頁(yè)設(shè)計(jì)公司微信小程序

廣告

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

成都做網(wǎng)站
亚洲国产日韩在线精品| 国产在线精品成人欧美| 亚洲美女毛茸茸的逼逼| 久久久久久狠狠亚洲综合| 亚洲欧美一区二区粉嫩| 国产精品毛片av在线| 日本黄色大波少妇网站| 国产成人综合亚洲乱淫.| 九九热精品只有这里有| 一区二区三区视频在线国产| 日韩欧美一区精品在线观看| 丰满熟女人妻中文字幕免费| 成人18禁视频免费看| 中文字幕日韩精品在线看| 在线高清中文字幕三区| 日本一区二区免费视频| 久久青草视频在线观看| 亚洲国产中文日韩欧美在线| 欧美日韩一级性生活片| 玩弄丰满熟妇班主任老师| 麻豆精品新av中文字幕| 亚洲国产精品一区二区av| 亚洲精品小视频在线观看| 美女网站色在线免费观看午夜精品| 看看美女阴逼毛茸茸的| 夫妻性生活视频一级片| 亚洲精品欧美综合第四区| 国产精品岛国片在线观看| 黑寡妇精品欧美一区二区毛| 福利视频免费观看欧美| 久久精品国产亚洲七七| 色国产精品一区在线观看| av小说亚洲激情乱| 国产亚洲理论片在线观看| 久久精品亚洲欧美麻豆| 国产呦精品一区二区三区| 青青草成人一区二区三区| 欧美亚洲五月婷婷激情| 亚洲视频一直看一直爽| 久久99精品国产99久久无| 一区二区三区视频观看在线|