vector自实现(一)
vector.h:
#ifndef __Vector__H__
#define __Vector__H__
typedef int Rank;
#define DEFAULT_CAPACITY 3 template<typename T> class Vector{
protected:
Rank _size; int _capacity; T*_elem;
void copyFrom(T const *A, Rank lo, Rank hi);
void expand();
void shrink();
void bubbleSort(Rank lo,Rank hi);
bool bubble(Rank lo,Rank hi);
void mergeSort(Rank lo,Rank hi);
void merge(Rank lo,Rank mi,Rank hi);
public:
Vector(int c = DEFAULT_CAPACITY,int s = 0, T v = 0)
{
_elem = new T[_capacity = s];
for (_size = 0; _size < s; _elem[_size++] = v);
}
Vector(T const *A, Rank n) { copyFrom(A, 0, n); }
Vector(T const *A, Rank lo, Rank hi) { copyFrom(A, lo, hi); }
Vector(Vector<T> const &V) { copyFrom(V._elem,0,V._size); }
Vector(Vector<T> const &V, Rank lo, Rank hi) { copyFrom(V._elem, lo, hi);}
~Vector(){delete[]_elem;} Rank size() const { return _size;}
bool empty() const { return !_size;}
Vector<T>& operator=(Vector<T> const&); T&operator[](Rank r) const; void unsort(Rank lo,Rank hi);
Rank find(T const& e,Rank lo,Rank hi) const;
Rank insert(Rank r,T const& e);
int remove(Rank lo,Rank hi);
T remove(Rank r);
int deduplicate();
int disordered() const; int uniquify(); void traverse(void(*)(T&));
template<typename VST> void traverse(VST&); static Rank binSearch(T* A,T const& e,Rank lo,Rank hi);
static Rank binSearch2(T* A, T const& e, Rank lo, Rank hi);
static Rank binSearch3(T* A, T const& e, Rank lo, Rank hi);
};
#endif
vector.cpp:
#include"Vector.h"
template<typename T>
void Vector<T>::copyFrom(T const * A, Rank lo, Rank hi)
{
_elem = new T[_capacity=2*(hi-lo)];
_size = 0;
while (lo < hi)
{
_elem[_size++] = A[lo++];
}
} template<typename T>
void Vector<T>::expand()
{
if (_size < _capacity)return;
if (_capacity < DEFAULT_CAPACITY) { _capacity = DEFAULT_CAPACITY; }
T*oldElem = _elem;
_elem = new T[_capacity<<=1];
for (int i = 0; i < _size; i++)
{
_elem[i] = oldElem[i];
}
delete[]oldElem;
} template<typename T>
void Vector<T>::shrink()
{
if (_capacity < DEFAULT_CAPACITY << 1)return;
if (_size << 2 > _capacity)return;
T *oldElem = _elem;
_elem = new T[_capacity>>=1];
for(int i = 0; i < _size; i++)
{
_elem[i] = oldElem[i];
}
delete[]oldElem;
} template<typename T>
void Vector<T>::bubbleSort(Rank lo, Rank hi)
{
while (!bubble(lo,hi--));
} template<typename T>
bool Vector<T>::bubble(Rank lo, Rank hi)
{
bool sorted = true;
while (++lo < hi)
{
if(_elem[lo - 1] < _elem[lo])
{
sorted = false;
swap(_elem[lo-1],_elem[lo]);
}
}
return sorted;
} template<typename T>
void Vector<T>::mergeSort(Rank lo, Rank hi)
{
if (hi - lo < 2) return;
int mi = (lo + hi) / 2;
mergeSort(lo,mi);
mergeSort(mi,hi);
merge(lo,mi,hi);
} template<typename T>
void Vector<T>::merge(Rank lo, Rank mi,Rank hi)
{
T *A = _elem + lo;
int lb = mi - lo;
T* B = new T[lb];
for (int i = 0; i < lb; i++) B[i] = A[i];
int rb = hi - mi;
T *C = _elem + mi;
for (Rank i=0,int j = 0, int k = 0; (j < lb) || (k < rb);)
{
if ((j<lb)&&(k>rb||(B[j] < C[k])))
{
A[i++] = B[j++];
}
if ((k<rb)&&(j>lb||(C[k]<=B[j])))
{
A[i++] = C[k++];
}
}
delete[] B; } template<typename T>
Vector<T>& Vector<T>::operator=(Vector<T> const & V)
{
if (_elem) delete[]_elem;
copyFrom(V._elem,0,V._size);
return *this;
} template<typename T>
T & Vector<T>::operator[](Rank r) const
{
return _elem[r];
} template<typename T>
void Vector<T>::unsort(Rank lo, Rank hi)
{
T* V = _elem + lo;
for(Rank i = hi - lo; i >= 0; i--)
{
swap(V[i-1] = V[rand()%i]);
}
} template<typename T>
Rank Vector<T>::find(T const & e, Rank lo, Rank hi) const
{
while((lo < hi--)&&(e!=_elem[hi]));
return hi;
} template<typename T>
Rank Vector<T>::insert(Rank r, T const & e)
{
expand();
for (int i = _size; i > r; i--)
{
_elem[i] = _elem[i-1];
}
_elem[r] = e;
_size++;
return r;
} template<typename T>
int Vector<T>::remove(Rank lo, Rank hi)
{
if (lo == hi)return 0;
while (hi < _size)
{
_elem[lo++] = _elem[hi++];
}
_size = lo;
shrink();
return hi - lo;
} template<typename T>
T Vector<T>::remove(Rank r)
{
T e = _elem[r];
remove(r,r+1);
return e;
} template<typename T>
int Vector<T>::deduplicate()
{
int oldsize = _size;
Rank i = 1;
while (i < _size)
{
(find(_elem[i], 0, _size) < 0) ? i++ : remove(i);
} return oldsize-_size; } template<typename T>
int Vector<T>::disordered() const
{
int n = 0;
for (int i = 1; i < _size; i++)
{
if(_elem[i - 1] > _elem[i])
{
n++;
}
}
return n;
} template<typename T>
int Vector<T>::uniquify()
{
Rank i = 0, j = 0;
while (++j < _size)
{
if (_elem[i] != _elem[j])
{
_elem[++i] = _elem[j];
}
}
_size = ++i;
shrink();
return j - i;
} template<typename T>
Rank Vector<T>::binSearch(T * A, T const & e, Rank lo, Rank hi)
{
while (lo < hi)
{
Rank mi = (lo + hi) >> 1;
if (e > A[mi])
{
lo = mi+1;
}
else if (e < A[mi])
{
hi = mi;
}
else {
return mi;
}
}
return -1;
} template<typename T>
Rank Vector<T>::binSearch2(T * A, T const & e, Rank lo, Rank hi)
{
while (1 < (hi - lo))
{
Rank mi = (lo + hi) >> 1;
(e < A[mi]) ? hi = mi : lo = mi;
}
return (e == A[lo]) ? lo : -1;
} template<typename T>
Rank Vector<T>::binSearch3(T * A, T const & e, Rank lo, Rank hi)
{
while (lo < hi)
{
Rank mi = (lo + hi) >> 1;
(e < A[mi]) ? hi = mi : lo = mi + 1;
}
return --lo;
} template<typename T>
void Vector<T>::traverse(void(*visit)(T &))
{
for (int i = 0; i < _size; i++)
{
visit(_elem[i]);
}
} template<typename T>
template<typename VST>
void Vector<T>::traverse(VST &visit)
{
for (int i = 0; i < _size; i++)
{
visit(_elem[i]);
}
}
vector自实现(一)的更多相关文章
- c++ vector 使用
1. 包含一个头文件: 1 #include <vector> 2. 申明及初始化: std::vector<int> first; // empty vector of in ...
- Vector Tile
Mapbox Vector Tile Specification A specification for encoding tiled vector data. <?XML:NAMESPACE ...
- ArrayList、Vector、LinkedList的区别联系?
1.ArrayList.Vector.LinkedList类都是java.util包中,均为可伸缩数组. 2.ArrayList和Vector底层都是数组实现的,所以,索引数据快,删除.插入数据慢. ...
- ArrayList、Vector、HashMap、HashSet的默认初始容量、加载因子、扩容增量
当底层实现涉及到扩容时,容器或重新分配一段更大的连续内存(如果是离散分配则不需要重新分配,离散分配都是插入新元素时动态分配内存),要将容器原来的数据全部复制到新的内存上,这无疑使效率大大降低. 加载因 ...
- Java中Vector和ArrayList的区别
首先看这两类都实现List接口,而List接口一共有三个实现类,分别是ArrayList.Vector和LinkedList.List用于存放多个元素,能够维护元素的次序,并且允许元素的重复.3个具体 ...
- C++使用vector
#include <iostream> #include <string> #include <vector> using namespace std; void ...
- [LeetCode] Flatten 2D Vector 压平二维向量
Implement an iterator to flatten a 2d vector. For example,Given 2d vector = [ [1,2], [3], [4,5,6] ] ...
- C++ 数组array与vector的比较
转:http://blog.csdn.net/yukin_xue/article/details/7391897 1. array 定义的时候必须定义数组的元素个数;而vector 不需要: 且只能包 ...
- vector定义初始化
头文件 #include<vector> using std::vector; vector<T> v1; vector<T> v2(v1); vector< ...
- vector迭代器用法
#include<iostream> #include<vector> using namespace std; int main() { vector<int> ...
随机推荐
- Signature Pad 使用
实现功能 能够在移动设备上实现电子签名,并保存为图片 git地址 https://github.com/szimek/signature_pad 参数说明 dotSize:点的大小(在屏幕上点击留下的 ...
- WPF DataGrid OxyPlot 卡顿优化
不是优化,我是想用这个标题吸引遇到相同问题的同学过来看看. UI如下,左边DataGrid有7列,右边OxyPlot显示折线图 列表4000+数据,折线图4000+个点,页面卡的用不了. 体现就是列表 ...
- 『与善仁』Appium基础 — 27、模拟手势点击坐标
目录 1.模拟手势点击坐标 2.tap()用法 3.练习 4.弊端 1.模拟手势点击坐标 在定位元素的时候,你使出了十八班武艺还是定位不到,怎么办呢?(面试经常会问) 那就拿出绝招:点击元素所在位置的 ...
- Qt5读取系统环境变量和获取指定目录下的所有文件夹绝对路径
头文件 /// 读取环境变量使用 #include <QProcessEnvironment> /// 遍历文件夹使用 #include <QDir> 核心代码 一个例子, 输 ...
- Android JNI 启动线程,并设置线程名称
p.p1 { margin: 0; font: 12px Menlo; color: rgba(100, 56, 32, 1); background-color: rgba(255, 255, 25 ...
- Redis 的 3 种集群方案对比
数据持久化 主从复制 自动故障恢复 集群化 数据持久化本质上是为了做数据备份,有了数据持久化,当Redis宕机时,我们可以把数据从磁盘上恢复回来,但在数据恢复之前,服务是不可用的,而且数据恢复的时间取 ...
- 洛谷——P1980 [NOIP2013 普及组] 计数问题
题目描述 试计算在区间 11 到 nn的所有整数中,数字x(0 ≤ x ≤ 9)x(0≤x≤9)共出现了多少次?例如,在 11到1111中,即在 1,2,3,4,5,6,7,8,9,10,111,2, ...
- Mysql 设计超市经营管理系统,包括员工库存表(stock) 和 仓库表(warehouse)
互联网技术学院周测机试题(三) 一.需求分析 为进一步完善连锁超市经营管理,提高管理效率,减少管理成本,决定开发一套商品管理系统,用于日常的管理.本系统分为商品管理.员工管理.店铺管理,库存管理等功能 ...
- linux 开启和关闭防火墙
Ubuntu #查看防火墙状态 sudo ufw status #开启防火墙 sudo ufw enable #关闭防火墙 sudo ufw disable CentOs #查看防火墙状态 syste ...
- Linux 进程调度
线程状态(context) 程序计数器(Program Counter),它表示当前线程执行指令的位置. 保存变量的寄存器. 程序的Stack.通常来说每个线程都有属于自己的Stack,Stack记录 ...