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

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

?? vector.h

?? 一個我的數據結構解題集合
?? 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
	};

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

	/* 檢查參數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:

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

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

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

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

	} // Vector(const Vector&)

	/* 析構函數, 清理所占用的資源
	 */
	~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;	// 需要的空間已經被滿足

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

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

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

		// 更新成員數據
		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中現存元素的數目
	 */
	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一区二区三区免费野_久草精品视频
亚洲国产视频一区| 亚洲一区二区在线免费看| 亚洲精品一线二线三线| 久久亚洲捆绑美女| 中文字幕一区二区5566日韩| 亚洲超丰满肉感bbw| 卡一卡二国产精品| 国产精品69毛片高清亚洲| 成人开心网精品视频| 在线观看免费亚洲| 日韩丝袜情趣美女图片| 国产日韩三级在线| 亚洲已满18点击进入久久| 国产一区不卡精品| 欧美丰满嫩嫩电影| 中文一区二区完整视频在线观看 | 日韩欧美国产wwwww| 欧美国产亚洲另类动漫| 亚洲国产精品精华液网站| 国产福利精品一区二区| 欧美sm美女调教| 亚洲综合免费观看高清完整版| 毛片不卡一区二区| 在线成人免费观看| 亚洲精品高清在线| 国产成人午夜视频| 精品国产乱码久久久久久牛牛| 亚洲一区二区三区视频在线播放| 国产乱码字幕精品高清av| 91精品综合久久久久久| 亚洲成在人线在线播放| 欧美在线观看禁18| 亚洲天堂精品视频| 色综合久久99| 亚洲成人自拍一区| 欧美一区二区三区在线| 久久99最新地址| 精品国产一区二区精华| 欧美aaaaaa午夜精品| 欧美一级高清片在线观看| 视频一区国产视频| 欧美mv日韩mv| 成人午夜精品在线| 日韩理论在线观看| 精品视频一区 二区 三区| 亚洲国产另类av| 日韩欧美综合一区| 不卡的电影网站| 天堂成人免费av电影一区| 日韩精品一区二| 成人午夜在线播放| 亚洲国产日韩在线一区模特| 91精品欧美综合在线观看最新| 国产精品亚洲人在线观看| 亚洲精品中文字幕在线观看| 欧美一级日韩一级| 成人手机在线视频| 婷婷综合另类小说色区| 337p粉嫩大胆色噜噜噜噜亚洲| 成人免费不卡视频| 天天做天天摸天天爽国产一区| 亚洲人快播电影网| 精品国产污污免费网站入口| 日本精品视频一区二区三区| 久久国产精品色| 亚洲制服丝袜在线| 中文字幕乱码亚洲精品一区| 8x8x8国产精品| 在线亚洲高清视频| av电影在线不卡| 国产精品一区一区| 麻豆精品一区二区三区| 亚洲欧美日韩在线不卡| 国产欧美日韩卡一| 精品成人一区二区三区四区| 欧美精品一卡两卡| 一本久久a久久精品亚洲| 成人av在线观| jizz一区二区| 91香蕉视频污在线| 色丁香久综合在线久综合在线观看| 国产在线精品一区二区不卡了| 午夜精品福利一区二区三区av| 亚洲午夜精品17c| 亚洲18影院在线观看| 亚洲成年人网站在线观看| 午夜精品在线视频一区| 首页亚洲欧美制服丝腿| 麻豆精品在线观看| 激情六月婷婷久久| 成人短视频下载| 欧洲精品一区二区三区在线观看| 欧美一区日韩一区| 久久蜜桃一区二区| 亚洲精品视频在线看| 亚洲国产精品一区二区尤物区| 日日夜夜精品视频免费| 国产一区999| 日韩你懂的在线观看| 午夜精品久久久久久久99樱桃| 一本久久精品一区二区| 亚洲国产一区二区视频| 亚洲国产乱码最新视频| 韩国视频一区二区| 精品少妇一区二区三区在线播放| 亚洲mv大片欧洲mv大片精品| 欧美人狂配大交3d怪物一区| 亚洲电影一级片| 欧美一区二区三区的| 亚洲国产综合色| 国产成人亚洲精品青草天美| 日本精品一区二区三区四区的功能| 欧美一区二区三区免费视频| 国产精品区一区二区三区| 亚洲一区二区三区四区在线免费观看| 免费高清在线一区| 欧美丝袜丝nylons| 亚洲视频一二区| www.日韩在线| 国产精品污网站| 国产成人免费高清| 26uuu国产在线精品一区二区| 日韩在线播放一区二区| 在线观看亚洲精品视频| 国产精品久久久久一区| 成人亚洲精品久久久久软件| 国产日韩一级二级三级| 国产精品一区二区免费不卡 | 亚洲成av人在线观看| 99久久99久久综合| 国产精品系列在线| 欧洲日韩一区二区三区| 免费观看久久久4p| 18成人在线视频| 欧美日韩国产一二三| 久草热8精品视频在线观看| 国产欧美一区二区精品仙草咪| 91欧美激情一区二区三区成人| 亚欧色一区w666天堂| 亚洲国产精品精华液2区45| 欧美系列亚洲系列| 国产一区二区三区免费| 亚洲最快最全在线视频| 久久久亚洲精华液精华液精华液| 欧美专区亚洲专区| 国产.精品.日韩.另类.中文.在线.播放| 一区二区三区蜜桃网| 久久精品视频在线免费观看| 5月丁香婷婷综合| 色婷婷激情综合| 成人av网址在线观看| 久久狠狠亚洲综合| 日韩精品久久久久久| 五月天一区二区三区| 综合精品久久久| 国产精品成人一区二区三区夜夜夜| 欧美一区二区三区思思人| 91视频观看免费| 成人午夜av电影| 国产精品中文有码| 国产一区91精品张津瑜| av日韩在线网站| caoporn国产一区二区| 蜜臀av性久久久久蜜臀aⅴ四虎| 91免费在线播放| 丝袜美腿亚洲一区二区图片| 久久国产乱子精品免费女| 粉嫩久久99精品久久久久久夜| 欧美影视一区二区三区| 精品国产免费一区二区三区四区| 国产精品日产欧美久久久久| 亚洲成人第一页| av亚洲精华国产精华精华| 91精品国产综合久久久久久久 | 美国十次了思思久久精品导航| 久久99精品国产麻豆不卡| 久草在线在线精品观看| 成人免费的视频| 欧美一区二区在线免费观看| 久久免费的精品国产v∧| 夜夜夜精品看看| 国产一区三区三区| 色婷婷香蕉在线一区二区| 91精品啪在线观看国产60岁| 国产精品福利一区二区| 老鸭窝一区二区久久精品| 色噜噜久久综合| 中文字幕av不卡| 久久国产精品99久久人人澡| 欧美亚洲高清一区二区三区不卡| 欧美变态口味重另类| 亚洲国产精品一区二区久久恐怖片| 精品在线一区二区| 7878成人国产在线观看| 综合在线观看色| 成人教育av在线| 国产精品区一区二区三区| 国产福利一区在线| 91麻豆精品国产91久久久更新时间| 国产精品成人午夜|