0210 在严酷漫长的寒冬中,我知道我身上有个不可战胜的夏日

跬步不惧,日拱一卒

1.cmp在类内问题

cmp类内要加static ,类外不用

 2.堆的实现基本是用优先队列

大顶堆:priority_queue<int,vector<int>,less<int>> bigQ;

小顶堆:priority_queue<int,vector<int>,greater<int>> smallQ;

3.const_iterator(不可改变其指向的值,猜测可以防止误操作)&&const iterator(基本没用)&&iterator区别

iterator与const_iterator

所有的标准库容器都定义了相应的迭代器类型。迭代器对所有的容器都适用,现代 C++ 程序更倾向于使用迭代器而不是下标操作访问容器元素。

1.iterator,const_iterator作用:遍历容器内的元素,并访问这些元素的值。iterator可以改元素值,但const_iterator不可改。跟C的指针有点像
(容器均可以++iter,而vector还可以iter-n, iter+n,n为一整型,iter1-iter2:结果是difference_type类型,表两元素的距离.)

2.const_iterator 对象可以用于const vector 或非 const vector,它自身的值可以改(可以指向其他元素),但不能改写其指向的元素值.

3.const iterator与const_iterator是不一样的:声明一个 const iterator时,必须初始化它。一旦被初始化后,就不能改变它的值,它一旦被初始化后,只能用它来

改它指的元素,不能使它指向其他元素。(因此const iterator几乎没什么用途)

     vector<int> nums(10); // nums is nonconst
     const vector<int>::iterator cit = nums.begin();
     *cit = 1;               // ok: cit can change its underlying element
     ++cit;                  // error: can't change the value of cit

猜你喜欢

转载自www.cnblogs.com/Marigolci/p/12290008.html