膜拜大佬:https://blog.csdn.net/xyz32768/article/details/88831233

题目链接:

http://codeforces.com/contest/1139/problem/F

题意:

有n个物品,物品有三个属性分别是$p_i,s_i,b_i$

有m个人,人有两个属性分别是$pref_j$,$inc_j$

一个人能买某个物品必须满足:,

$p_i \leq inc_j \leq s_i$

$|b_i-pref_j| \leq (inc_j-p_i)$

求出每个人能买物品的数量、

数据范围:

$1 \leq n \leq 10^5$

$1 \leq m \leq 10^5$

其它都是$1$到$10^9$


分析:

借用大佬的图片,描述物品的影响:

对$p_i,s_i,inc_j$进行扫描线处理,$p_i$时提取出$b_i$的影响,$s_i$时取消$b_i$的影响,$inc_j$时对$j$进行计算答案,计算$pref_j$在几个黄色三角形的影响里面。

一个点$(x,y)$受$b_i$影响需要满足下面的条件:

$x-y\geq p_i-b_i$时,$b_i$的影响加一

$-x-y\geq -p_i-b_i+1$时,$b_i$的影响减一

对这两个影响条件分别建立一个离散化的数状数组

具体实现看代码

ac代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e5+10;
struct Node
{
int is,id,x;
bool operator <(const Node &a)const
{
if(x!=a.x)return x<a.x;
else return is<a.is;
}
};
int a[maxn*4],s[maxn],p[maxn],inc[maxn],b[maxn],treea[maxn*4],treeb[maxn*4],pb[maxn];
int ans[maxn];
map<int,int>ma;
int cnt=0,tt=0;
Node que[maxn*3];
int getid(int x)
{
x=-x;
return ma[x];
}
void add1(int x,int y)
{
for(int i=x;i<4*maxn;i+=(i&-i))treea[i]+=y;
}
void add2(int x,int y)
{
for(int i=x;i<4*maxn;i+=(i&-i))treeb[i]+=-y;
}
int quer1(int x)
{
int res=0;
for(int i=x;i>=1;i-=(i&-i))res+=treea[i];
return res;
}
int quer2(int x)
{
int res=0;
for(int i=x;i>=1;i-=(i&-i))res+=treeb[i];
return res;
}
int main()
{
int n,m;
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++)scanf("%d",&p[i]);
for(int i=1;i<=n;i++)scanf("%d",&s[i]);
for(int i=1;i<=n;i++)scanf("%d",&b[i]);
for(int i=1;i<=m;i++)scanf("%d",&inc[i]);
for(int i=1;i<=m;i++)scanf("%d",&pb[i]); for(int i=1;i<=n;i++)
{
a[++cnt]=-(p[i]+b[i]-1),a[++cnt]=-(b[i]-p[i]);
que[++tt]=Node{0,i,p[i]};
que[++tt]=Node{2,i,s[i]};
} for(int i=1;i<=m;i++)
{
a[++cnt]=-(inc[i]+pb[i]),a[++cnt]=-(pb[i]-inc[i]);
que[++tt]=Node{1,i,inc[i]};
}
sort(que+1,que+1+tt);
sort(a+1,a+cnt+1);
int pz=1;
for(int i=1;i<=cnt;i++)
if(ma[a[i]]==0)ma[a[i]]=pz++; for(int i=1;i<=tt;i++)
{ Node now=que[i];
if(now.is==0)
{
add1(getid(b[now.id]-p[now.id]),1);
add2(getid(p[now.id]+b[now.id]-1),1);
}
else if(now.is==1)
{
ans[now.id]=quer1(getid(pb[now.id]-inc[now.id]))+quer2(getid(inc[now.id]+pb[now.id]));
}
else if(now.is==2)
{
add1(getid(b[now.id]-p[now.id]),-1);
add2(getid(p[now.id]+b[now.id]-1),-1);
}
}
for(int i=1;i<=m;i++)
{
printf("%d ",ans[i]);
}
return 0;
}

  

codeforces#1139F. Dish Shopping (离散化数组数组+ 扫描线)的更多相关文章

  1. Codeforces 1139F Dish Shopping 树状数组套平衡树 || 平衡树

    Dish Shopping 将每个物品拆成p 和 s 再加上人排序. 然后问题就变成了, 对于一个线段(L - R), 问有多少个(li, ri)满足  L >= li && R ...

  2. 【BZOJ1818】[CQOI2010]内部白点(树状数组,扫描线)

    [BZOJ1818][CQOI2010]内部白点(树状数组,扫描线) 题面 BZOJ 题解 不难发现\(-1\)就是在搞笑的. 那么对于每一行,我们显然可以处理出来最左和最右的点,那么等价于我们在横着 ...

  3. [Codeforces 1208D]Restore Permutation (树状数组)

    [Codeforces 1208D]Restore Permutation (树状数组) 题面 有一个长度为n的排列a.对于每个元素i,\(s_i\)表示\(\sum_{j=1,a_j<a_i} ...

  4. c/c++ 函数指针 指针函数 数组的引用 指针数组 数组指针

    1.指针数组数组指针 引用数组 数组的引用 int *a[10] 指针数组 每一个元素都是一个指针 Int (*a)[10] 数组指针 P指向一个含有10个元素的数组 Int (&a)[10] ...

  5. 指针数组  数组指针的区别.xml

    pre{ line-height:1; color:#1e1e1e; background-color:#f0f0f0; font-size:16px;}.sysFunc{color:#627cf6; ...

  6. 指针数组&数组指针

    数组指针(也称行指针) 定义 int (*p)[n]; ()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长.也就是说执行p+1时,p要跨过n个整型数 ...

  7. [ 随手记 2 ] C/C++ 数组/指针/传数组到函数/指针数组/数组指针

    1.=================================================================== 1,数组是一块内存连续的数据.2,指针是一个指向内存空间的变 ...

  8. c/c++ 数组 数组的引用,指针数组的引用

    c/c++ 数组 知识点 1,数组的声明和初始化,对应代码里的test1和test2 2,char数组,对应代码里的test3 3,数组不可以拷贝和复制,对应代码里的test4 4,指针数组, 数组的 ...

  9. 【IT笔试面试题整理】字符串转数组+数组转字符串

    [试题描述]定义一个函数,字符串转数组数组转字符串 [参考代码] public static int strToInt(String str) { int i = 0, num = 0; char[] ...

随机推荐

  1. C#类型(一)

    1.System.Object C#的所有类型都是派生自System.Object 也就是说下面的两个类型定义完全一致 // 隐式派生自Object public class Person{ } { ...

  2. Java成神之路技术整理(长期更新)

    以下是Java技术栈微信公众号发布的关于 Java 的技术干货,从以下几个方面汇总. Java 基础篇 Java 集合篇 Java 多线程篇 Java JVM篇 Java 进阶篇 Java 新特性篇 ...

  3. 从零开始搭建运维体系 - ansible

    从零开始搭建运维体系 - ansible 基本配置好了局域网内的机器后,第一个遇到的问题就是如何批量操作这么多台机器,ansible就是这么一个自动化运维工具. ansible是一个基于ssh的批量远 ...

  4. okhttputils【 Android 一个改善的okHttp封装库】使用(二)

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 上一篇讲了如何在项目中导入OKHttputils库的操作,这一篇主要讲常见请求的写法. get请求 public String getPe ...

  5. 认识JWT

    1. JSON Web Token是什么 JSON Web Token (JWT)是一个开放标准(RFC 7519),它定义了一种紧凑的.自包含的方式,用于作为JSON对象在各方之间安全地传输信息.该 ...

  6. Java数组协变与范型不变性

    变性是OOP语言不变的大坑,Java的数组协变就是其中的一口老坑.因为最近踩到了,便做一个记录.顺便也提一下范型的变性. 解释数组协变之前,先明确三个相关的概念,协变.不变和逆变. 一.协变.不变.逆 ...

  7. .NET开发中基础问题,CODE First AND DB First(大牛自动忽略,小白可以看一下)

    最近在做一个新项目开发时,碰到了下面这个问题.在使用EF时,提示错误信息 To continue using Database First or Model First ensure that the ...

  8. 从零开始学安全(四十一)●初识Wireshark

    wireshark:Beyond Compare是一个网络封包分析软件.网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料.Wireshark使用WinPCAP作为接口,直接与 ...

  9. ASP.NET WebApi系列

    ASP.NET Web API 是一种框架,用于轻松构建可以访问多种客户端(包括浏览器和移动设备)的 HTTP 服务. ASP.NET Web API 是一种用于在 .NET Framework 上构 ...

  10. 五分钟读懂UML类图(转)

    平时阅读一些远吗分析类文章或是设计应用架构时没少与UML类图打交道.实际上,UML类图中最常用到的元素五分钟就能掌握,下面赶紧来一起认识一下它吧: 一.类的属性的表示方式 在UML类图中,类使用包含类 ...