STL(Standard Template Library)主要由两种组件构成:容器(container)和操作容器类的泛型算法(generic algorithm)。
容器包括:vector、list、set、map等。其中vector和list是熟悉容器。一次从第一个元素到最后一个。主要进行迭代(iterate)操作。map和set是关联容器。可以快速寻找容器中任意值。map由成对的key/value组成,key用于查找,value存放数据。例如通讯录中姓名用作key,号码用作value。set仅含key,查找时是判断某值是否存在于所有值中。
所有容器共通操作:
泛型算法是操作容器类的行为,不关心数据类型,于容器相互独立。包括70多种:
search 查找:find(),count() adjacent_find(),find_if(),count_if(),binary_search(),find_first_of(). sorting(排序)、ordering(整理):merge(),partial_sort(),partition(),random_shuffle(),reverse(),rotate(),sort(). copy(复制)、deletion(删除)、substitution(替换):copy(),remove(),remove_if(),replace(),replace_if(),swap(),unique(). relational(关系):equal(),includes(),mismatch(). generation(生成)、mutation(质变):fill(),for_each(),generate(),transform(). numeric(计数):accmulate(),adjacent_difference(),partial_sum(),inner_product(). set(集合):set_union(),set_difference().查找某值:
template
elemType * find(const vector &vec, elemType value){
for(int i = 0; i < vec.size(); i++){
if(vec[i] == value)
return &vec[i];
return 0;
}
}
作者:雲烟