唯一化:
有序/无序序列中,任意/总有一对相邻元素顺序/逆序。因此,相邻逆序对的数目,可用以度量向量的逆序程度。
template <typename T>//返回逆序相邻元素对的总数
int Vector<T>::disordered() const{
int n = 0;//计数器
for(int i = 1;i<_size; i++){//逐一检查各对相邻元素
n += (_elem[i-1]>_elem[i]);//逆序则计数
}
return n;//向量有序当且仅当n = 0
}//若只需要判断是否有序,则首次遇到逆序对后,即可立即终止
有序向量的去重操作:
(1)低效算法:在有序向量中,重复的元素必然是存在于相互紧邻的区间,因此在每个区间只要保留单个元素即可,
template <typename T> int Vector<T>::