洛谷p3801:红色的幻想乡

初见完全没有思路.....感觉像是线段树 但二维感觉完全不可做嘛
于是只能去看了看题解 然而还是疯狂爆零+WA..
和yycc神犇调了两三个小时才调出来...
——————以下个人理解
考虑到每次的修改都是对整行和整列进行操作
可以把每行缩成一个点 这样修改就相当于对这个点进行单点修改
同理也把每列缩成一个点
那么对于每一次修改操作 我们只需要将这个点的横坐标与纵坐标进行修改即可
也就是维护两棵线段树,分别表示行和列
显然可以看出对于图里的每一个点,只有有红雾和没红雾两种状态,并且又说两次红雾会抵消
于是每一次修改就相当于做一次取反操作 还需要支持的另一个操作就是朴素的区间求和
但这显然不是正解 因为每一次操作时实际对于蕾咪所在的那个点是完全没有影响的 而在我们的修改时没有考虑到这一点
似乎没有什么好办法?......好像标记的话会退化回O(Nlogn)....
当然是选择容斥它辣.....但是蒟蒻博主也不会...我太弱啦!
又请教了一下yycc神犇
画图可知 a条横着的直线与b条竖着的直线的交点数为a*b
而每一个交点我们在横竖修改的时候都分别对他对多标记了一次
所以只需在结果上减去一个ansx*ansy*2就是答案了
码农题
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
#include<stack>
#include<set>
#include<map>
#include<limits.h>
#include<ctime>
#define N 1000001
typedef long long ll;
const int inf=0x3fffffff;
const int maxn=2017;
using namespace std;
inline ll read()
{
ll f=1,x=0;char ch=getchar();
while(ch>'9'|ch<'0')
{
if(ch=='-')
f=-1;
ch=getchar();
}
while(ch<='9'&&ch>='0')
{
x=(x<<3)+(x<<1)+ch-'0';
ch=getchar();
}
return f*x;
}
struct tsdl{
ll w;
}xtr[N],ytr[N];
void updatex(ll l,ll r,ll pos,ll x)
{
if(l==r)
{
xtr[pos].w^=1;
return;
}
ll mid=l+r>>1;
if(mid>=x)updatex(l,mid,pos<<1,x);
else updatex(mid+1,r,pos<<1|1,x);
xtr[pos].w=xtr[pos<<1].w+xtr[pos<<1|1].w;
}
void updatey(ll l,ll r,ll pos,ll x)
{
if(l==r)
{
ytr[pos].w^=1;
return;
}
ll mid=l+r>>1;
if(mid>=x)updatey(l,mid,pos<<1,x);
else updatey(mid+1,r,pos<<1|1,x);
ytr[pos].w=ytr[pos<<1].w+ytr[pos<<1|1].w;
}
ll queryx(ll l,ll r,ll a,ll b,ll pos)
{
if(l>=a&&r<=b)
{
return xtr[pos].w;
}
ll ans=0;
ll mid=l+r>>1;
if(mid>=a)ans+=queryx(l,mid,a,b,pos<<1);
if(mid<b)ans+=queryx(mid+1,r,a,b,pos<<1|1);
return ans;
}
ll queryy(ll l,ll r,ll a,ll b,ll pos)
{
if(l>=a&&r<=b)
{
return ytr[pos].w;
}
ll ans=0;
ll mid=l+r>>1;
if(mid>=a)ans+=queryy(l,mid,a,b,pos<<1);
if(mid<b)ans+=queryy(mid+1,r,a,b,pos<<1|1);
return ans;
}
int main()
{
ll n=read(),m=read(),k=read();
while(k--)
{
ll opt=read();
switch(opt)
{
case 1:
{
ll x=read(),y=read();
updatex(1,n,1,x);
updatey(1,m,1,y);
break;
}
case 2:
{
ll ans=0;
ll xa=read(),ya=read(),xb=read(),yb=read();
ll ansx=queryx(1,n,xa,xb,1);
ll ansy=queryy(1,m,ya,yb,1);
cout<<ansy*(xb-xa+1)+ansx*(yb-ya+1)-ansx*ansy*2<<endl;
}
}
}
}

洛谷p3801:红色的幻想乡的更多相关文章
- 洛谷——P3801 红色的幻想乡
P3801 红色的幻想乡 推荐阅读 https://blog.csdn.net/qq_41252892/article/details/79035942 非常清楚 线段树单点修改 emmm没什么了 # ...
- 洛谷 P3801 红色的幻想乡
题目背景 蕾米莉亚的红雾异变失败后,很不甘心. 题目描述 经过上次失败后,蕾米莉亚决定再次发动红雾异变,但为了防止被灵梦退治,她决定将红雾以奇怪的阵势释放. 我们将幻想乡看做是一个n*m的方格地区,一 ...
- [luogu P3801] 红色的幻想乡 [线段树][树状数组]
题目背景 蕾米莉亚的红雾异变失败后,很不甘心. 题目描述 经过上次失败后,蕾米莉亚决定再次发动红雾异变,但为了防止被灵梦退治,她决定将红雾以奇怪的阵势释放. 我们将幻想乡看做是一个n*m的方格地区,一 ...
- 【洛谷3345_BZOJ3924】[ZJOI2015]幻想乡战略游戏(点分树)
大概有整整一个月没更博客了 -- 4 月为省选爆肝了一个月,最后压线进 B 队,也算给 NOIP2018 翻车到 316 分压线省一这个折磨了五个月的 debuff 画上了一个不算太差的句号.结果省选 ...
- luogu P3801 红色的幻想乡
嘟嘟嘟 首先人人都能想到是线段树,不过二维线段树肯定会MLE+TLE的. 我们换一种想法,不去修改整个区间,而是修改一个点:开横竖两个线段树,分别记录哪些行和列被修改了.因为如果两阵红雾碰撞,则会因为 ...
- AC日记——红色的幻想乡 洛谷 P3801
红色的幻想乡 思路: 线段树+容斥原理: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 100005 #de ...
- [luogu3801]红色的幻想乡
题目描述 经过上次失败后,蕾米莉亚决定再次发动红雾异变,但为了防止被灵梦退治,她决定将红雾以奇怪的阵势释放. 我们将幻想乡看做是一个n*m的方格地区,一开始没有任何一个地区被红雾遮盖.蕾米莉亚每次站在 ...
- 洛谷P3224 [HNOI2012]永无乡(线段树合并+并查集)
题目描述 永无乡包含 nnn 座岛,编号从 111 到 nnn ,每座岛都有自己的独一无二的重要度,按照重要度可以将这 nnn 座岛排名,名次用 111 到 nnn 来表示.某些岛之间由巨大的桥连接, ...
- 洛谷 P3224 [HNOI2012]永无乡
题面 永无乡包含 \(n\) 座岛,编号从 \(1\) 到 \(n\) ,每座岛都有自己的独一无二的重要度,按照重要度可以将这 \(n\) 座岛排名,名次用 \(1\) 到 \(n\) 来表示.某些岛 ...
随机推荐
- junit测试
/**ssm框架测试service**/ import com.alibaba.fastjson.JSON; import com.raycloud.waimai.customer.center.po ...
- js分享功能(微信,QQ,微博,空间,豆瓣等)
日常编程中,我们可能会碰到项目中的分享功能,各大平台都有分享接口和文档说明,当然也有一些一键分享插件,例如:sosh,iShare.js等等 但有些同学不想引用插件,那么我整理了一些常用的分享至平台功 ...
- fatal error: Eigen3/Core: 没有那个文件或目录
解决方法: 在CMakeLists.txt文件里添加: include_directories("/usr/include/eigen3")
- 【vue】组件使用Deferred特性
延迟加载组件 defer的意思是"延迟",所以deferred对象的含义就是"延迟"到未来某个点再执行. <template> <div> ...
- mysql命令行的导入导出sql,txt,excel(都在linux或windows命令行操作)(转自筑梦悠然)
原文链接https://blog.csdn.net/wuhuagu_wuhuaguo/article/details/73805962 Mysql导入导出sql,txt,excel 首先我们通过命令行 ...
- git上传到版本库报错:Pull is not possible because you have unmerged files(已解决)
问题所在:操作次数太多,第一次报错之删掉了.git并没有删除下面两个文件 才报了题述错误. 解决办法: 将这三个文件都删除在重新运行所有指令.
- TableView+Button
local MainScene = class("MainScene", cc.load("mvc").ViewBase) function MainScene ...
- Android 插件化和热修复知识梳理
概述 在Android开发中,插件化和热修复的话题越来越多的被大家提及,同时随着技术的迭代,各种框架的发展更新,插件化和热修复的框架似乎已经日趋成熟,许多开发者也把这两项技术运用到实际开发协作和正式的 ...
- django中常用的数据查询方法
https://blog.csdn.net/chen1042246612/article/details/84071006
- Centos 部署.net Core
1.安装net core框架 sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc sudo sh -c 'echo ...