这个题真的难了我一天了,这种方法一开始没想出来,后来看了题解后明白了大致思路开始自己做但是!!!但是自己实现的时候老是一些细节出错!!!,调bug调了得有一个小时,蠢死了,这道题我一定要好好总结,总结为什么会卡壳,这要是比赛的签到题的话我得哭死!!!!!

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e5+;
unsigned long long a[maxn];
unsigned long long c[maxn];
unsigned long long sum[maxn];
set<unsigned long long> s;
int main()
{
int n;
cin>>n;
for(int i=; i<=n; i++)
{
unsigned long long t;
cin>>t;
s.insert(t);
}
int cnt=;
for(auto i:s)
a[++cnt]=i;
for(int i=; i<=cnt-; i++)
c[i]=a[i+]-a[i];
cnt--;
sort(c+,c++cnt);
for(int i=; i<=cnt; i++)
sum[i]=sum[i-]+c[i];
int q;
cin>>q;
while(q--)
{
unsigned long long l,r;
cin>>l>>r;
unsigned long long t=r-l;
unsigned long long pos;
unsigned long long ans=;
pos=upper_bound(c+,c++cnt,t)-c;
ans+=+t;
ans+=(sum[pos-]);
ans+=(cnt-pos+)*(t+);
cout<<ans<<endl;
} }

读题之后我的最直接的思路是把这n个数,去重排序,然后是比较两两之间的长度与r-l的区间长度的关系然后一直累加出答案。如下超时代码。

我应该要注意到这两两之间的差值也是可以排序的,排完序之后只要在小于等于r-l的区间长度的都是我下面if语句的第一条,大于r-l区间长度的都是else语句的内容,这个判断可以二分来实现,同时对于小于等于区间长度的可以用预先求出前缀和来快速计算。

#include<bits/stdc++.h>
using namespace std;
set<unsigned long long> s;
const int maxn=1e5+;
unsigned long long a[maxn];
unsigned long long b[maxn];
int main()
{
int n;
cin>>n;
for(int i=; i<=n; i++)
cin>>a[i];
int q;
cin>>q;
while(q--)
{
unsigned long long l,r;
s.clear();
memset(b,,sizeof(b));
cin>>l>>r;
for(int i=; i<=n; i++)
s.insert(a[i]+l);
unsigned long long t=r-l;
int cnt=;
for(auto i:s)
b[++cnt]=i;
unsigned long long ans=;
for(int i=; i<=cnt-; i++)
{
if((b[i]+t)>=b[i+])
ans+=b[i+]-b[i];
else
ans+=t+;
}
ans+=t+;
printf("%lld\n",ans); }
}

D. Frets On Fire 前缀和+二分的更多相关文章

  1. cf1119d Frets On Fire 前缀和+二分

    题目:http://codeforces.com/problemset/problem/1119/D 题意:给一个数n,给出n个数组的第一个数(a[0]=m,a[1]=m+1,a[2]=m+2,... ...

  2. D. Frets On Fire 【二分,前缀和】 (Codeforces Global Round 2)

    题目传送门:http://codeforces.com/contest/1119/problem/D D. Frets On Fire time limit per test 1.5 seconds ...

  3. Codeforces Global Round 2 D. Frets On Fire (动态开点线段树,沙雕写法)

    题目链接:D. Frets On Fire 思路:明明可以离散化+二分写,思路硬是歪到了线段树上,自闭了,真实弟弟,怪不得其他人过得那么快 只和查询的区间长度有关系,排完序如果相邻的两个点的差值小于等 ...

  4. Glider(前缀和+二分)

    题目链接:Glider Gym-101911B 解题分析:下落的高度一定,是h.在没有气流的地方每秒下落1:所以可以转化为经过无气流地带的时间总长为h. 那么很显然从一个有气流地带的开始,选择下落,那 ...

  5. Acwing:102. 最佳牛围栏(前缀和 + 二分)

    农夫约翰的农场由 NN 块田地组成,每块地里都有一定数量的牛,其数量不会少于1头,也不会超过2000头. 约翰希望用围栏将一部分连续的田地围起来,并使得围起来的区域内每块地包含的牛的数量的平均值达到最 ...

  6. Codeforces 975 前缀和二分算存活人数 思维离直线速度相同判平行

    A /* Huyyt */ #include <bits/stdc++.h> using namespace std; typedef long long ll; ]; ]; map< ...

  7. Codeforces 948 数论推导 融雪前缀和二分check 01字典树带删除

    A. 全部空的放狗 B. 先O(NLOGNLOGN)处理出一个合数质因数中最大的质数是多少 因为p1 x1 x2的关系是 x2是p在x1之上的最小倍数 所以x1的范围是[x2-p+1,x2-1]要使最 ...

  8. cf-Global Round2-D. Frets On Fire(二分)

    题目链接:http://codeforces.com/contest/1119/problem/D 题意:给n(<=1e5)个数s[i],i=1..n,(0<=s[i]<=1e18) ...

  9. Educational Codeforces Round 11 C. Hard Process 前缀和+二分

    题目链接: http://codeforces.com/contest/660/problem/C 题意: 将最多k个0变成1,使得连续的1的个数最大 题解: 二分连续的1的个数x.用前缀和判断区间[ ...

随机推荐

  1. webpack4.0学习记录

    2019/04/28 1.本质上,webpack基于node  node跟webpack为最新稳定版,才能更好,更快的打包 安装 1.卸载node  直接在控制面板  卸载 2.安装 从官网下载 然后 ...

  2. 2018-2019-2 20165325《网络对抗技术》Exp0 Kali安装 Week1

    2018-2019-2 20165325<网络对抗技术>Exp0 Kali安装 Week1 一.安装kali VMware上学期已经有了,主要是下载Kali-Linux-2019.1-vm ...

  3. python操作redis命令

    Python操作redis from redis import StrictRedis, ConnectionPoolredis_url="redis://:xxxx@112.27.10.1 ...

  4. 深度学习之自编码器AutoEncoder

    原文地址:https://blog.csdn.net/marsjhao/article/details/73480859 一.什么是自编码器(Autoencoder) 自动编码器是一种数据的压缩算法, ...

  5. 从头开始学Maven【仓库】

    仓库的分类 本地仓库 改setting.xml 文件中的 <localRepository/> 远程仓库 远程仓库的配置 远程仓库的认证 部署至远程仓库 中央仓库 在$M2_HOME/li ...

  6. django学习笔记-模板层

    模板层 将Python嵌入到HTML中. 模板简介 将HTML硬解码到视图并不是那么完美原因如下: 对页面设计时也需要对python代码进行相应的修改,模板可以不就行python代码修改的情况下变更设 ...

  7. MUI之App开发

    一般开发APP分为两种:1.原生ios和android语言开发.2.混合开发,里边穿插h5的东西. 3.第三种:现在因为前端用hbuilder工具开发的情况越来越多,这家公司又提供了更多的选择,所以近 ...

  8. 论文阅读笔记四十七:Generalized Intersection over Union: A Metric and A Loss for Bounding Box Regression(CVPR2019)

    论文原址:https://arxiv.org/pdf/1902.09630.pdf github:https://github.com/generalized-iou 摘要 在目标检测的评测体系中,I ...

  9. 华为指标OceanStore

    https://support.huawei.com/enterprise/zh/doc/EDOC1000086637?idPath=7919749%7C7941815%7C21430818%7C21 ...

  10. SVN 通过Shell Bash 获取项目Reversion号码

    接上篇  Jenkins Vue项目自动构建以及构建后续操作 在项目构建完成后,需要提供当前构建的一个唯一标识的东西,并告诉我们的上线系统,这个唯一标识的东西可以让我们在回退线上版本的时候变得很有用, ...