亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? vector.h

?? 一個我的數(shù)據(jù)結構解題集合
?? H
字號:
#ifndef VECTOR_H__
#define VECTOR_H__

#include <algorithm>	// 使用std::swap
#include <sstream>		// 使用std::stringstream
#include <stdexcept>

template <typename T>
class Vector {
private:

	enum {
		INIT_SIZE = 10		// 初始大小, 必須大于0
	};

	/* 數(shù)據(jù)內部存儲結構為循環(huán)存儲結構
	 * data_	 指向被分配內存的首地址;
	 * begin_	 首個有效數(shù)據(jù)的下標;
	 * end_		 最后一個有效數(shù)據(jù)下標邏輯上的后一位
	 * capacity_ 已分配的空間大小
	 *
	 *	數(shù)據(jù)儲存于 [begin_, end_) 區(qū)間內
	 *	以begin_ == end_作為Vector為空標志,
	 *	為data_分配的空間總比實際利用空間多至少1,
	 *	以檢查Vector滿的情況
	 */
	T *data_;
	int begin_;
	int end_;
	int capacity_;

	/* 檢查參數(shù)index是否在合法范圍內, 
	 * 若超出范圍, 拋出std::out_of_range異常, 
	 * 否則返回
	 */
	void checkRange(int index) const {
		if ( 0 <= index && index < size() ) return;

		using namespace std;
		// 生成錯誤信息
		stringstream buf;
		buf << "Vector: Index out of range!\n"
			<< "\tSize: "	<< size()
			<< "\tIndex: "	<< index
			<< endl;

		throw out_of_range(buf.str());

	} // checkRange(int) const

	/* 返回邏輯上index的下一個位置
	 */
	int incr(int index) const {
		return (index+1) % capacity_;
	} // incr(int) const

	/* 返回邏輯上index的上一個位置
	 */
	int decr(int index) const {
		if (index == 0)
			return capacity_-1;
		else
			return index-1;
	} // decr(int) const

public:

	/* 構造函數(shù), 初始化Vector使之為空并且有保留INIT_SIZE個T的空間
	 */
	Vector() {
		data_ = new T[INIT_SIZE];
		capacity_ = INIT_SIZE;
		begin_ = end_ = 0;
	} // Vector()

	/* 拷貝構造函數(shù), 從that創(chuàng)建Vector,
	 * 使被創(chuàng)建的Vector所具有的元素和that相同
	 */
	Vector(const Vector& that) {
		capacity_ = that.size() + INIT_SIZE;	// 確定分配空間大小

		data_ = new T[capacity_];	// 分配空間

		// 拷貝數(shù)據(jù)
		for (int i=0, j=that.begin_; j != that.end_; ++i, j=that.incr(j)) {
			data_[i] = that.data_[j];
		}
		
		// 更新成員數(shù)據(jù)
		begin_ = 0;
		end_ = that.size();

	} // Vector(const Vector&)

	/* 析構函數(shù), 清理所占用的資源
	 */
	~Vector() {
		delete [] data_;
	} // ~Vector()

	/* 賦值操作將當前Vector賦值為that
	 */
	Vector& operator=(const Vector& that) {
		if (this == &that) return *this;	// 自我賦值

		Vector v(that);		// 拷貝that的值
		swap(v);			// 保存到this

		return *this;
	} // operator=(const Vector&)

	/* 交換兩個Vector的內容
	 */
	void swap(Vector& that) {
		if (this == &that) return;	// 自我交換

		using std::swap;
		swap(data_, that.data_);
		swap(begin_, that.begin_);
		swap(end_, that.end_);
		swap(capacity_, that.capacity_);
	} // swap(Vector&)

	/* 將元素e插入Vector的頭部
	 * 若空間不足自動分配
	 */
	void pushFront(const T& e) {
		if ( size()+1 >= capacity_ )
			reserve(1 + capacity_*1.5);
		data_[decr(begin_)] = e;
		begin_ = decr(begin_);
	} // pushFront(const T&)

	/* 將元素e插入Vector的尾端
	 * 若空間不足自動分配
	 */
	void pushBack(const T& e) {
		if ( size()+1 >= capacity_ )
			reserve(1 + capacity_*1.5);
		data_[end_] = e;
		end_ = incr(end_);
	} // pushBack(const T&)

	/* 將頭部元素刪除
	 * 如果Vector為空, 拋出std::underflow_error異常
	 */
	void removeFront() {
		if (size() <= 0) {
			throw std::underflow_error("Vector: Underflow!\n"
									   "\tOperation: removeFront()\n");
		}
		begin_ = incr(begin_);
	} // removeFront()

	/* 將尾部元素刪除
	 * 如果Vector為空, 拋出std::underflow_error異常
	 */
	void removeBack() {
		if (size() <= 0) {
			throw std::underflow_error("Vector: Underflow!\n"
									   "\tOperation: removeBack()\n");
		}
		end_ = decr(end_);
	} // removeBack()

	/* 查詢頭部元素
	 * 如果Vector為空, 拋出std::out_of_range異常
	 */
	const T& front() const {
		checkRange(0);
		return data_[begin_];
	} // front() const

	/* 查詢尾部元素
 	 * 如果Vector為空, 拋出std::out_of_range異常
	 */
	const T& back() const {
		checkRange(size()-1);
		return data_[decr(end_)];
	} // back() const

	/* 查詢位置為index的元素
	 * 如果index不滿足 0 <= index && index < size(),
	 * 拋出out_of_range異常
	 * 提供const和非const兩個版本
	 */
	T& operator[](int index) {
		checkRange(index);
		return data_[(begin_ + index) % capacity_];
	} // operator[](int)

	const T& operator[](int index) const {
		checkRange(index);
		return data_[(begin_ + index) % capacity_];
	} // operator[](int) const


	/* 預留至少capacity的空間
	 */
	void reserve(int capacity) {
		if (capacity <= capacity_) return;	// 需要的空間已經(jīng)被滿足

		T *new_data = new T[capacity];		// 分配新的空間

		// 拷貝數(shù)據(jù)
		int i, j;
		for (i=0, j=begin_; j != end_; ++i, j=incr(j)) {
			new_data[i] = data_[j];
		}

		delete [] data_;					// 釋放舊的空間

		// 更新成員數(shù)據(jù)
		data_ = new_data;
		capacity_ = capacity;

		begin_ = 0;
		end_ = i;

	} // reserve(int)

	/* 將向量增大到sz大小
	 */
	void enlarge(int sz) {
		reserve(sz+1);
		end_ = (begin_ + sz) % capacity_;
	} // enlarge(int)

	/* 查詢預留空間的大小
	 */
	int capacity() const {
		return capacity_;
	} // capacity() const

	/* 查詢Vector中現(xiàn)存元素的數(shù)目
	 */
	int size() const {
		return (begin_ <= end_) ?
			   (end_ - begin_) :
			   (end_ + capacity_ - begin_);
	} // size() const

	/* 查詢Vector是否為空
	 */
	bool isEmpty() const {
		return size() == 0;
	} // isEmpty() const

}; // Vector



#endif // VECTOR_H__

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91在线精品一区二区| 欧美一区二区黄色| 欧美一区二区三区四区久久| 国产婷婷色一区二区三区| 国产精品美女www爽爽爽| 亚洲.国产.中文慕字在线| 福利一区二区在线| 欧美大片一区二区三区| 一区二区在线观看av| 国产一区二区精品在线观看| 欧美视频一区在线观看| 国产精品色在线观看| 精品一区二区三区av| 欧美主播一区二区三区美女| 国产精品无圣光一区二区| 裸体歌舞表演一区二区| 欧美三级欧美一级| 亚洲精品欧美在线| 成人精品免费网站| 国产性做久久久久久| 激情亚洲综合在线| 日韩亚洲欧美成人一区| 亚洲资源中文字幕| 一本大道av一区二区在线播放 | 欧美一区二区成人| 亚洲自拍偷拍网站| 欧美视频一区二区| 性做久久久久久久免费看| 91黄色免费网站| 亚洲激情五月婷婷| 色综合久久久久久久久| 亚洲欧美区自拍先锋| 99久久综合色| 亚洲精品午夜久久久| 97se亚洲国产综合自在线不卡| 国产精品第一页第二页第三页| 成人动漫av在线| 中文字幕欧美一| 色婷婷久久久综合中文字幕| 亚洲欧美另类小说视频| 色噜噜狠狠成人网p站| 亚洲裸体在线观看| 欧美午夜电影网| 日本一道高清亚洲日美韩| 日韩一区二区免费视频| 韩国在线一区二区| 中文字幕制服丝袜成人av| 99r国产精品| 亚洲自拍偷拍图区| 欧美一区二区三级| 老司机精品视频在线| 国产日韩欧美亚洲| 91久久国产最好的精华液| 国产91精品一区二区麻豆亚洲| 国产亚洲一区二区三区在线观看 | 精品久久一区二区| 国产精品一线二线三线精华| 国产精品久久三区| 欧美日韩在线综合| 精品一区二区三区不卡| 中文字幕一区二区日韩精品绯色| 成人永久aaa| 一二三区精品福利视频| 日韩欧美久久一区| 成人午夜电影久久影院| 亚洲国产成人av网| 国产肉丝袜一区二区| 日本高清视频一区二区| 另类调教123区 | 色天天综合色天天久久| 日本麻豆一区二区三区视频| 亚洲国产成人午夜在线一区| 欧美午夜精品理论片a级按摩| 久久99国产精品久久99| 亚洲欧洲日韩在线| 日韩精品一区二区三区在线播放| av在线不卡观看免费观看| 日韩电影一区二区三区四区| 欧美极品另类videosde| 这里只有精品免费| 91蜜桃在线观看| 久久国产欧美日韩精品| 亚洲午夜av在线| 国产精品久久久久婷婷| 日韩一区二区三区在线视频| 99视频热这里只有精品免费| 美女免费视频一区| 午夜久久久久久| 亚洲人成人一区二区在线观看 | www.亚洲国产| 激情av综合网| 全部av―极品视觉盛宴亚洲| 亚洲精品写真福利| 中文字幕 久热精品 视频在线| 91精品国产综合久久久蜜臀图片| 91浏览器打开| a4yy欧美一区二区三区| 国产美女主播视频一区| 久久99精品网久久| 日本色综合中文字幕| 亚洲第一二三四区| 一区二区国产视频| 一区二区三区精品在线| 中文字幕一区二区三| 国产精品情趣视频| 国产欧美1区2区3区| 久久综合色一综合色88| 日韩欧美视频在线| 日韩欧美一级精品久久| 日韩欧美在线1卡| 91精品国产色综合久久不卡蜜臀| 欧美色区777第一页| 欧美性做爰猛烈叫床潮| 在线观看亚洲一区| 欧美性三三影院| 在线不卡一区二区| 欧美一区二区三区啪啪| 日韩限制级电影在线观看| 日韩一区二区三区在线| 日韩欧美一级精品久久| 精品国产乱码久久久久久浪潮| 精品久久久三级丝袜| 久久女同性恋中文字幕| 中文字幕免费在线观看视频一区| 国产欧美一区二区精品性色| 国产精品美女www爽爽爽| 亚洲天堂av一区| 日韩精品高清不卡| 韩国欧美一区二区| 成人午夜免费av| 欧美在线观看视频在线| 日韩亚洲欧美在线观看| 久久日韩粉嫩一区二区三区| 国产精品美女一区二区三区| 亚洲色图.com| 午夜电影一区二区| 精品一区二区三区在线播放视频| 国产成人在线网站| 在线欧美一区二区| 欧美一级二级三级蜜桃| 国产视频不卡一区| 亚洲永久精品国产| 蜜桃传媒麻豆第一区在线观看| 国产999精品久久久久久绿帽| 色综合色综合色综合色综合色综合| 欧美日韩精品一区二区在线播放| 精品久久久网站| 一区二区国产盗摄色噜噜| 久久91精品国产91久久小草| eeuss鲁一区二区三区| 在线观看91精品国产麻豆| 久久久综合视频| 亚洲午夜三级在线| 国产一区二区不卡在线| 欧美网站大全在线观看| 国产日韩高清在线| 午夜精品一区二区三区免费视频| 国产精品88av| 欧美高清视频不卡网| 国产精品久久久久影院老司| 美女视频第一区二区三区免费观看网站| 不卡的看片网站| 91精品婷婷国产综合久久| 中文字幕不卡在线| 免费观看日韩av| 在线一区二区三区| 久久看人人爽人人| 免费观看一级欧美片| 欧美丝袜丝nylons| 国产精品久久久久影院老司| 久久99国产精品尤物| 欧美老肥妇做.爰bbww| 国产精品国产三级国产三级人妇| 激情五月播播久久久精品| 欧美猛男男办公室激情| 亚洲欧美日韩国产手机在线| 国产午夜精品美女毛片视频| 免费精品视频最新在线| 99综合电影在线视频| 日韩欧美中文字幕制服| 一区二区高清免费观看影视大全 | 亚洲激情校园春色| 国内精品伊人久久久久av影院 | 亚洲欧美在线视频| 韩国av一区二区三区在线观看| 欧美三区免费完整视频在线观看| 国产精品久久久久久久久免费桃花| 韩国v欧美v亚洲v日本v| 欧美一区二区三区人| 午夜私人影院久久久久| 欧美午夜一区二区三区| 亚洲蜜桃精久久久久久久| 成人黄色一级视频| 中文字幕日本不卡| 成人午夜在线视频| 最好看的中文字幕久久| av亚洲精华国产精华| 成人欧美一区二区三区1314| 99在线精品一区二区三区| 国产精品乱人伦一区二区|