UVA12663 【High bridge, low bridge】

差分

题目大意:一共有n座桥,每个桥都有一个高度,海水每次都会涨落,问被淹次数大于等于k的桥一共有多少座。

对于海水的涨落,可以看成是区间加法(被淹的桥次数加一),暴力搞的话肯定会TLE,所以我们珂以用差分来实现区间加法,从l到r加上x就相当于差分数组里的l处+x,r+1处-x,因为这个题还需要记录上一次海水所在的位置,所以我们珂以这样写:

for(int i=1;i<=m;++i)
{
    scanf("%d%d",&x,&y);
    mp[pre+1]++;
    mp[x+1]--;pre=y;
}

又因为这道题的数据范围比较大,可以离散化来解决,我们还可以使用map来实现(因为我比较懒),直接使用迭代器遍历就珂以啦~差分的时间复杂度为\(O(nlong(n))\)O(能过),可能没有线段树跑的快(毕竟map的常数太大了),但我们还是能开心地A掉这道题啦。

最后献上我丑陋的代码

#include<algorithm>
#include<iostream>
#include<cstdio>
#include<map>
#define IT map<int,int>::iterator 
using namespace std;
const int N=100010;
int n,m,k,my_case,ans,sum,pre,x,y;
int b[N];
map<int,int>mp;
int main()
{
    while(scanf("%d%d%d",&n,&m,&k)==3)
    {
        ans=sum=pre=0;mp.clear();
        for(int i=1;i<=n;++i)scanf("%d",&b[i]);
        for(int i=1;i<=m;++i)
        {
            scanf("%d%d",&x,&y);
            mp[pre+1]++;
            mp[x+1]--;pre=y;
        }
        for(IT it=mp.begin();it!=mp.end();++it)
        {
            sum+=it->second;
            it->second=sum;
        }
        for(int i=1;i<=n;++i)
        {
            IT it=mp.lower_bound(b[i]);
            ans+=(((--it)->second)>=k);
        }
        printf("Case %d: %d\n",++my_case,ans);
    }
    return 0;
}

转载于:https://www.cnblogs.com/wljss/p/11547358.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值