STL
大部分容器之前都用过了,但是依然学到了一些新的用法:
- vector提高性能,
emplace_back
比push_back
快 - unordered_map哈希实现,比map快一点
- 去重,
vec.erase(unique(vec.begin(), vec.end()), vec.end())
__gcd()
自带,不用手写了- 有序的容器记得重载<
P2286[HNOI2004]宠物收养场比较适合用来练习set的各种操作
分治、二分
分治是很常见的思想了,比如在快速排序里
void qsort(int l,int r)
{
int mid=a[(l+r)/2];
int i=l,j=r;
do{
while(a[i]<mid) i++;
while(a[j]>mid) j--;
if(i<=j){
swap(a[i],a[j]);
i++,j--;
}
}while(i<=j);
if(l<j) qsort(l,j);
if(i<r) qsort(i,r);
}
二分答案的想法也经常用到,一般出现“使XXX的最大值最小”之类的题就是这么做的。但是有些二分答案的题 check()
函数不太好写,记得以前做过一道插花的题就是这样。
/*二分答案*/
while(l<=r){
mid=(l+r)/2;
if(check(mid))
ans=mid,l=mid+1;
else
r=mid-1;
}
贪心
贪心的思想比较简单,我做到过的比较难的贪心题都结合了其他的知识,比如P1080国王游戏和P2123皇后游戏之类,有时候即便想到了可以贪心也推不出后续的过程。。。