codeforces#1139F. Dish Shopping (离散化数组数组+ 扫描线)
膜拜大佬: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 (离散化数组数组+ 扫描线)的更多相关文章
- Codeforces 1139F Dish Shopping 树状数组套平衡树 || 平衡树
Dish Shopping 将每个物品拆成p 和 s 再加上人排序. 然后问题就变成了, 对于一个线段(L - R), 问有多少个(li, ri)满足 L >= li && R ...
- 【BZOJ1818】[CQOI2010]内部白点(树状数组,扫描线)
[BZOJ1818][CQOI2010]内部白点(树状数组,扫描线) 题面 BZOJ 题解 不难发现\(-1\)就是在搞笑的. 那么对于每一行,我们显然可以处理出来最左和最右的点,那么等价于我们在横着 ...
- [Codeforces 1208D]Restore Permutation (树状数组)
[Codeforces 1208D]Restore Permutation (树状数组) 题面 有一个长度为n的排列a.对于每个元素i,\(s_i\)表示\(\sum_{j=1,a_j<a_i} ...
- c/c++ 函数指针 指针函数 数组的引用 指针数组 数组指针
1.指针数组数组指针 引用数组 数组的引用 int *a[10] 指针数组 每一个元素都是一个指针 Int (*a)[10] 数组指针 P指向一个含有10个元素的数组 Int (&a)[10] ...
- 指针数组 数组指针的区别.xml
pre{ line-height:1; color:#1e1e1e; background-color:#f0f0f0; font-size:16px;}.sysFunc{color:#627cf6; ...
- 指针数组&数组指针
数组指针(也称行指针) 定义 int (*p)[n]; ()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长.也就是说执行p+1时,p要跨过n个整型数 ...
- [ 随手记 2 ] C/C++ 数组/指针/传数组到函数/指针数组/数组指针
1.=================================================================== 1,数组是一块内存连续的数据.2,指针是一个指向内存空间的变 ...
- c/c++ 数组 数组的引用,指针数组的引用
c/c++ 数组 知识点 1,数组的声明和初始化,对应代码里的test1和test2 2,char数组,对应代码里的test3 3,数组不可以拷贝和复制,对应代码里的test4 4,指针数组, 数组的 ...
- 【IT笔试面试题整理】字符串转数组+数组转字符串
[试题描述]定义一个函数,字符串转数组数组转字符串 [参考代码] public static int strToInt(String str) { int i = 0, num = 0; char[] ...
随机推荐
- 吴恩达机器学习笔记59-向量化:低秩矩阵分解与均值归一化(Vectorization: Low Rank Matrix Factorization & Mean Normalization)
一.向量化:低秩矩阵分解 之前我们介绍了协同过滤算法,本节介绍该算法的向量化实现,以及说说有关该算法可以做的其他事情. 举例:1.当给出一件产品时,你能否找到与之相关的其它产品.2.一位用户最近看上一 ...
- PHP面向对象特性
目录 创建对象 成员属性 成员方法 构造方法 析构方法 垃圾回收机制 访问修饰符 魔术方法 对象比较 继承 重载 属性重载 方法重写 属性重写 静态属性 静态方法 多态 类型约束 抽象类 接口 fin ...
- Ubuntu 18.04.1 LTS + kolla-ansible 部署 openstack Rocky all-in-one 环境
1. kolla 项目介绍 简介 kolla 的使命是为 openstack 云平台提供生产级别的.开箱即用的自动化部署能力. kolla 要实现 openetack 部署分为两步,第一步是制作 do ...
- Vue(day8)
继续上一篇文章的内容,本文主要内容为项目中新闻资讯模块的实现. 新闻资讯页面主要是当我们点击这个按钮时跳转到新闻列表界面. 一.新闻资讯的路由设计 将新闻资讯的标签改为路由:(a标签改为router- ...
- MYSQL的group by笔记
对应的表数据如下 现在的需求是要找出dcid为9951,9957,9064共同拥有的good_code. 第一种方案是 SELECT a.good_code FROM ( SELECT good_co ...
- 01 JVM 从入门到实战 | 什么是 JVM
什么是 JVM 先来看下百度百科的解释: JVM 是 Java Virtual Machine(Java 虚拟机)的缩写,JVM 是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算 ...
- 【Spark篇】---Spark中Shuffle文件的寻址
一.前述 Spark中Shuffle文件的寻址是一个文件底层的管理机制,所以还是有必要了解一下的. 二.架构图 三.基本概念: 1) MapOutputTracker MapOutputTracker ...
- 《深入理解Java虚拟机》-----第3章 垃圾收集器与内存分配策略
Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的“高墙”,墙外面的人想进去,墙里面的人却想出来. 3.1 概述 说起垃圾收集(Garbage Collection,GC),大部分人都把这 ...
- 【Android Studio安装部署系列】十三、Android studio添加和删除Module
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 新建.导入.删除Module是常见的操作,这里简单介绍下. 新建Module File——New——New Module... 选中 ...
- Node.js 命令行工具的编写
日常开发中,编写 Node.js 命令行工具来完成一些小任务是很常见的操作.其编写也不难,和日常编写 Node.js 代码并无二致. package.json 中的 bin 字段 一个 npm 模块, ...