2020暑期训练1

STL

大部分容器之前都用过了,但是依然学到了一些新的用法:

  • vector提高性能, emplace_backpush_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皇后游戏之类,有时候即便想到了可以贪心也推不出后续的过程。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值