题意:给一个如图坐标系,每个方形都放在下面两个中间,已知一个木块湿了那么他下面所有的都会湿,显然,不能湿两次。问,每次给出一个坐标,把他弄湿,有几个木块从干变成湿了。

思路:我们把坐标系拉直,就变成了如图,显然我们弄湿 a(0,5),那么红色部分变湿,看一眼应该已经找到计算面积的方法了。所以我们每次得到一个坐标,我们就能直接算出面积。然后我们判断,是否已经有顶点所产生的面积包含了我的顶点,是的话我湿的面积为0。没有的话我就遍历一遍所有顶点,删掉所有的已经湿了的面积,剩下的就是新湿的面积了。

然后我们看一下,如果两个面积不相交,那么必有下图这样,我们可以简单的算出,红色最右边的x应该为a.x + a.y,那么不相交的条件为a.x + a.y < b.x。

相含的时候,被包含的那个面积必然是从包含的面积内部一点为顶点,而红色内部所有的点都有一个性质x + y <= a.x + a.y && x >= a.x,所以以此判断包含关系。

然后计算交集:显然交集为蓝色减去它内部小红色的面积。那么我们先判断是否有内含,有的话就是被含的面积;否则我们找出红色小面积的顶点,因为我们知道y的长度就可以算出面积,那么Y = a.x + a.y - b.x。

但是我们直接减去相交面积显然不行,因为可能有很多重复的面积被我减掉了。那怎么办?直接计算每次多减的加回去,多算的面积是两两之间的交集,一直加到最后一块和我相交的(也就是x >= a.x且不内含的第一块)。

代码:

#include<cmath>
#include<set>
#include<map>
#include<queue>
#include<cstdio>
#include<vector>
#include<cstring>
#include <iostream>
#include<algorithm>
#include<unordered_map>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int maxn = 1e5 + 10;
const int M = maxn * 30;
const ull seed = 131;
const int INF = 0x3f3f3f3f;
const int MOD = 1e4 + 7;
struct Tri{
ll x, y;
bool operator < (const Tri a) const{
return x < a.x;
}
};
set<Tri> s;
ll getAera(Tri a){
return (1LL + a.y) * (a.y + 2LL) / 2LL;
}
bool contain(Tri a, Tri b){ //a包含b
return a.x + a.y >= b.x + b.y && a.x <= b.x;
}
ll intersect(Tri a, Tri b){ //a b交集
if(contain(a, b)) return getAera(b);
else if(contain(b, a)) return getAera(a);
else{
ll y = -1;
if(a.x <= b.x) y = max(y, a.x + a.y - b.x);
else y = max(y, b.x + b.y - a.x);
return getAera(Tri{1, y});
}
}
int main(){
int n;
scanf("%d", &n);
s.clear();
while(n--){
Tri a;
scanf("%lld%lld", &a.x, &a.y);
auto it = s.upper_bound(a);
if(it != s.begin()) it--; //第一个x小于等于a.x的位置
if(s.begin() != s.end() && contain(*it, a)){ //a被包含
printf("0\n");
continue;
}
ll ret = getAera(a);
for(auto i = it; i != s.end();){
ret -= intersect(a, *i);
if(!contain(a, *i) && (*i).x >= a.x) break;
auto pre = i++;
if(i == s.end()) break;
ret += intersect(*i, *pre);
}
for(auto i = it; i != s.end();){
if(contain(a, *i)) s.erase(i++);
else i++;
}
s.insert(a);
printf("%lld\n", ret);
}
return 0;
}

Gym 100796B Wet Boxes(思维)题解的更多相关文章

  1. Codeforces GYM 100876 J - Buying roads 题解

    Codeforces GYM 100876 J - Buying roads 题解 才不是因为有了图床来测试一下呢,哼( 题意 给你\(N\)个点,\(M\)条带权边的无向图,选出\(K\)条边,使得 ...

  2. Gym 101128A Promotions(思维 + dfs)题解

    题意:给一有向图,如果A指向B,则A是B的上级.一直i要升职那么他的上级必须都升职.现在给你一个升职人数的区间[a, b],问你升职a人时几个人必被升职,b时几个人必升职,b时几个人没有可能被升职. ...

  3. Gym 102028C - Supreme Command - [思维题][2018-2019 ACM-ICPC Asia Jiaozuo Regional Contest Problem C]

    题目链接:https://codeforces.com/gym/102028/problem/C Lewis likes playing chess. Now he has n rooks on th ...

  4. Gym 101775C - Traffic Light - [思维题]

    题目链接:http://codeforces.com/gym/101775/problem/C 题意: 给出 $N$ 个红绿灯,又给出 $N+1$ 个距离 $S_i = S_0,S_1, \cdots ...

  5. C. Okabe and Boxes 思维 模拟 or 线段树

    C. Okabe and Boxes 这个题目是一个有点思维的模拟,当时没有想到, 思维就是这个栈的排序这里,因为每次直接排序肯定会t的,所以不可以这么写,那怎么表示排序呢? 就是直接把栈清空,如果栈 ...

  6. Gym 100801E Easy Arithmetic (思维题)

    题目:传送门.(需要下载PDF) 题意:给定一个长度不超过1000的字符串表达式,向该表达式中加入'+'或'-',使得表达式的值最大,输出该表达式. 题解:比如300-456就改成300-4+56,遇 ...

  7. A - Arcade Game Gym - 100814A (概率思维题)

    题目链接:https://cn.vjudge.net/contest/285964#problem/A 题目大意:每一次给你你一个数,然后对于每一次操作,可以将当前的数的每一位互换,如果互换后的数小于 ...

  8. G - WiFi Password Gym - 101608G (异或思维题+曲尺)

    题目链接:https://cn.vjudge.net/contest/285962#problem/G 题目大意:给你n和m,n代表有n个数,然后让你找出一个最长的区间,使得这个区间内的所有的数的‘’ ...

  9. L - Looking for Taste Gym - 101991L 二进制枚举/思维

    方法一:因为最多是10的六次方,所以可以直接枚举二进制上的每一位来得到最优结果. AC代码: #include<iostream> #include<stack> #inclu ...

随机推荐

  1. django form和form组件

    form介绍: 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是 ...

  2. CoeMonkey少儿编程第4章 变量

    点击这里,现在就开启CodeMonkey的趣味编程之旅. 目标 了解什么是变量 了解变量的命名规则 掌握如何使用变量 变量 什么是变量?顾名思义,变量就是可以变化的量. 和变量相对的是常量,即不可变化 ...

  3. 前端面试准备笔记之JavaScript(02)

    01. this的典型应用场景 this在各个场景中取什么值,是在函数执行的时候确认的,不是在定义的时候确认的. 普通函数执行 返回window function fn1() { console.lo ...

  4. Error Code: 2006 - MySQL 5.7 server has gone away

    使用 Navicat 执行 sql 脚本失败 出现 Error Code: 2006 - MySQL server has gone away 原因 当MySQL客户端或mysqld服务器收到大于ma ...

  5. MDX学习笔记(整理) MDX语法

    1.1.members和Children的用法. select [Measures].[Internet Sales Count] on columns, [客户].[全名] on rows from ...

  6. the minimum number of bits required to represent x 最小位数

    src/math/bits/bits.go:296 // --- Len ---// Len returns the minimum number of bits required to repres ...

  7. WPF学习里程(二) XAML基础

    1.什么是XAML? 官方语言: XAML是eXtensible Application Markup Language的英文缩写,相应的中文名称为可扩展应用程序标记语言,它是微软公司为构建应用程序用 ...

  8. springboot配置rabbitmq

    一.消息生成者 1.1消息生成者配置 1.2 消息发送端代码 1.3 创建交换机,队列,并建立关系 二.消费者 2.1消费者 三.限流配置 3.1配置文件 #在单个请求中处理的消息个数,他应该大于等于 ...

  9. python 文件的方法

    1.open() 方法 Python open() 方法用于打开一个文件,并返回文件对象,在对文件进行处理过程都需要使用到这个函数,如果该文件无法被打开,会抛出 OSError. 注意:使用 open ...

  10. Java——继承,重载,重写三剑客

    About-继承 所有Java的类均是由java.lang.Object类继承而来的,所以Object是所有类的祖先类,而除了Object外,所有类必须有一个父类. 继承可以理解为一个对象从另一个对象 ...