Hopping Rabbit

Hopping Rabbit

题意:

给你n个矩阵,每个矩阵(给出左上标和右下标),现在让你给出一个点的位置,这个点每次只能上下左右四个方向移动,且移动距离为d,是否存在一个这样的点,其所有落点都不在矩阵内。

题解:

能到达的位置都是周期重复的,比如当前点在(x,y),那么可以到达(x+d,y),(x+2d,y),所以我们将所有(k1d,k2d)到(k1d+d,k2d+d)范围内的所有图形移动至(1,1)到(d,d)范围内,相当于整体大地图上彼此可以到达的点当作一个点,这样就得到一个d * d的小地图
同样矩阵也会被带到这个小地图,矩阵所覆盖小地图的部分说明在这个位置跳终究会跳到矩阵中,所以我要找是否存在一个点没有被矩阵覆盖。
那问题就变成n个矩阵移动至(1,1)到(d,d)范围内求并,这是扫描先的典型操作。我们用扫描线求每一行的最小值,如果存在0说明有个点没有被覆盖,记录坐标,否在就是全部被覆盖
情况如图:

在这里插入图片描述

代码:

#include<bits/stdc++.h>
#define debug(a,b) printf("%s = %d\n",a,b);
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;
clock_t startTime, endTime;
//Fe~Jozky
const ll INF_ll=1e18;
const int INF_int=0x3f3f3f3f;
inline ll read(){ll s=0,w=1ll;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1ll;ch=getchar();}while(ch>='0'&&ch<='9') s=s*10ll+((ch-'0')*1ll),ch=getchar();//s=(s<<3)+(s<<1)+(ch^48);return s*w;
}
void rd_test(){#ifdef ONLINE_JUDGE#elsestartTime = clock(); //计时开始freopen("in.txt","r",stdin);#endif
}
void Time_test(){#ifdef ONLINE_JUDGE#elseendTime = clock(); //计时结束printf("\n运行时间为:%lfs\n",(double)(endTime - startTime) / CLOCKS_PER_SEC);#endif
}
const int N=200010;#define lson (id<<1)
#define rson ((id<<1)|1)
#define mid ((l+r)>>1)struct Node
{int val,add,mul;
}tr[N<<2];void push_up(int id,int l,int r)
{tr[id].val=min(tr[lson].val,tr[rson].val);
}void solve(int id,int mul,int add){tr[id].add=tr[id].add*mul+add;tr[id].mul=tr[id].mul*mul;tr[id].val=tr[id].val*mul+add;
}
void push_down(int id){solve(id<<1,tr[id].mul,tr[id].add);solve(id<<1|1,tr[id].mul,tr[id].add);tr[id].mul=1;tr[id].add=0;
}void build(int id,int l,int r)
{tr[id].mul=1;tr[id].add=0;if (l==r){tr[id].val=0;return;}build(lson,l,mid);build(rson,mid+1,r);push_up(id,l,r);
}void update(int id,int l,int r,int L,int R,int mul,int add)
{if (L<=l && R>=r){solve(id,mul,add);return;}push_down(id);if (mid>=R) update(lson,l,mid,L,R,mul,add);else if (mid<L) update(rson,mid+1,r,L,R,mul,add);else{update(lson,l,mid,L,mid,mul,add);update(rson,mid+1,r,mid+1,R,mul,add);}push_up(id,l,r);
}int query(int id,int l,int r,int L,int R)
{if (L<=l && R>=r) return tr[id].val;push_down(id);if (mid>=R) return query(lson,l,mid,L,R);if (mid<L) return query(rson,mid+1,r,L,R);return min(query(lson,l,mid,L,mid),query(rson,mid+1,r,mid+1,R));
}int n,d;
vector<pair<int,int>> add[N],del[N];void upd(int x1,int y1,int x2,int y2)
{int xl=0,xr=0,yl=0,yr=0;if (x2-x1>=d){xl=1;xr=d;}else{xl=(x1%d+d)%d+1;xr=((x2-1)%d+d)%d+1;}if (y2-y1>=d){yl=1;yr=d;}else{yl=(y1%d+d)%d+1;yr=((y2-1)%d+d)%d+1;}if (xl<=xr){if (yl<=yr){add[yl].push_back({xl,xr});del[yr+1].push_back({xl,xr});}else//列拆分成两部分 {add[1].push_back({xl,xr});del[yr+1].push_back({xl,xr});add[yl].push_back({xl,xr});del[d+1].push_back({xl,xr});}}else//行拆分成两部分 {if (yl<=yr){add[yl].push_back({1,xr});add[yl].push_back({xl,d});del[yr+1].push_back({1,xr});del[yr+1].push_back({xl,d});}else{add[1].push_back({1,xr});add[1].push_back({xl,d});del[yr+1].push_back({1,xr});del[yr+1].push_back({xl,d});add[yl].push_back({1,xr});add[yl].push_back({xl,d});del[d+1].push_back({1,xr});del[d+1].push_back({xl,d});}}
}int main()
{scanf("%d%d",&n,&d);int x1=0,y1=0,x2=0,y2=0;for (int i=1;i<=n;i++){scanf("%d%d%d%d",&x1,&y1,&x2,&y2);upd(x1,y1,x2,y2);}build(1,1,d);int ansx=0,ansy=0;for (int y=1;y<=d;y++){for (PII it:add[y]){update(1,1,d,it.first,it.second,1,1);}for (PII it :del[y]){update(1,1,d,it.first,it.second,1,-1);}if (query(1,1,d,1,d)==0)//如果存在空隙,找到空隙坐标 {for (int x=1;x<=d;x++){if (query(1,1,d,x,x)==0){ansx=x;ansy=y;break;}}break;}}if (!ansx) printf("NO\n");else printf("YES\n%d %d\n",ansx-1+d,ansy-1+d);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/316491.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

删好串(区间dp)

problem 定义长度为 nnn 的“好”的串 aaa 满足&#xff1a; ∣ai−ai−1∣1,i∈[2,n]|a_i-a_{i-1}|1,i\in[2,n]∣ai​−ai−1​∣1,i∈[2,n]。ai≥ai−1ai12,i∈[2,n−1]a_i\ge \frac{a_{i-1}a_{i1}}{2},i\in[2,n-1]ai​≥2ai−1​ai1​​,i∈[2,n−1]。 给定长度为 nnn 的序…

直播预告 - 微软MVP为你揭秘Visual Studio 2019新特性

作为"宇宙第一IDE“的Visual Studio集成开发环境&#xff0c;已经经历了超过十几年的迭代成为一款功能丰富且高效的开发工具&#xff0c;微软自己给Visual Studio 的定位是 “更快、更可靠&#xff0c;对个人和团队更具生产力&#xff0c;更易于使用&#xff0c;并且更容易…

Delete Edges

Delete Edges 题意&#xff1a; 给出一个n个点的完全图&#xff0c;删一些三元环使得边数<n 输出所删的三元环 3<n<2000 题解&#xff1a; 肯定是结论题&#xff0c;但是我不会。。 结论&#xff1a;xyz0(mod n)1<x<y<z<n所有解即可 证明过程可以看看…

.NET 机器学习生态调查

机器学习是一种允许计算机使用现有数据预测未来行为、结果和趋势的数据科学方法。 使用机器学习&#xff0c;计算机可以在未显式编程的情况下进行学习。机器学习的预测可以使得应用和设备更智能。 在线购物时&#xff0c;机器学习基于历史购买推荐你可能喜欢的其他产品。 刷信用…

图中异色点对最短距离(最小生成树+线段树)

problem 给定一个 nnn 个点&#xff0c;mmm 条边的无向连通图&#xff0c;图有边权&#xff0c;每个点有一个颜色。 有 qqq 次操作&#xff0c;每次操作可更改某一个点颜色。 求每次操作后图中不同颜色点之间的最短距离。 若图中点颜色全相同&#xff0c;输出 000。 一行给…

Defend Your Country

Defend Your Country 题意&#xff1a; n个点&#xff0c;m条边的简单无向连通图&#xff0c;每个点一个权值ai,一个连通块的贡献&#xff1a;(−1)块内点数∗∑ai[点i在该连通块内](-1)^{块内点数}*\sum a_{i}[点i在该连通块内](−1)块内点数∗∑ai​[点i在该连通块内] 可以…

SkyWalking Liunx 环境搭建NetCore接入

背景前两天看见有小哥介绍windows下安装skywalking的介绍地址。正好最近也在搭建linux环境的SkyWalking&#xff0c;顺便把linux环境搭建的经验分享下&#xff0c;帮助下使用linux部署DotNetCore项目的同学。介绍SkyWalking是开源的apm工具&#xff0c;服务器端使用java编写&am…

AtCoder 2305 [AGC010D] Decrementing(博弈)

problem Luogu链接 solution case1&#xff1a;aaa 中如果有 111 的存在&#xff0c;那么相当于第二步失效&#xff0c;最后的结果仅由 ∑ai−1\sum a_i-1∑ai​−1 的奇偶性决定&#xff08;奇数先手赢&#xff0c;偶数后手赢&#xff09; 奇数先手赢&#xff0c;偶数后手…

P4568 [JLOI2011]飞行路线

P4568 [JLOI2011]飞行路线 题意&#xff1a; n个城市&#xff0c;m个航班&#xff0c;你有k次免费坐航班的机会&#xff0c;问从s到t最少花费是多少&#xff1f; 题解&#xff1a; 分层图问题 简单说说什么是分层图&#xff1a; 其实就是将一个平面的图重新建图&#xff0c…

.NET 基金会完成第一次全面改选

.NET基金会是一个独立的组织&#xff0c;支持.NET社区和开源&#xff0c;旨在拓宽和加强.NET生态系统和社区。这可以通过多种方式完成&#xff0c;包括项目指导&#xff0c;指导&#xff0c;法律和营销帮助&#xff0c;技术和财务支持设置等&#xff0c;2014年微软组织成立.NET…

一般图带权多重匹配(欧拉图+最小费用流)

problem 给定 nnn 个数 {ai}\{a_i\}{ai​}&#xff0c;其中 kkk 个 aia_iai​ 是奇数&#xff0c;再给一个 nnn\times nnn 的矩阵 {ci,j}\{c_{i,j}\}{ci,j​}&#xff0c;无论是 aaa 还是 ccc&#xff0c;都保证是非负整数。 现在可以做一类操作&#xff1a;将 ai−1,aj−1a_…

xay loves trees

xay loves trees 题意&#xff1a; 有两棵树&#xff0c;现在让你找到一个最大的点集合S&#xff0c;要求S中的点在第一棵树中任意两点存在祖先儿子关系且所有点是连接的&#xff0c;在第二棵树中任意两点都不存在祖先儿子关系&#xff0c;问S集合的最大是多少&#xff1f; …

特来电混沌工程实践

一、导语随着大型分布式系统架构的演进和广泛应用&#xff0c;软件工程的最佳实践也随之改变。我们通过分布式、服务化、DevOps、敏捷开发&#xff0c;快速响应业务的需求变化&#xff0c;支持大规模分布式应用。但这些做法带来效益的同时&#xff0c;也带来了另一个紧迫问题&a…

[ZJOI2007] 棋盘制作(单调栈 / DP悬线法)

problem 洛谷链接 solution1-单调栈 很容易想到&#xff0c;预处理出每个点向上最大能延伸的长度&#xff0c;然后对每个点求一个矩阵面积。 然后思考优化&#xff0c;不难想到每次对一行进行求解。 每一行的所有列一起构成了一个直方图。 直方图直接经典笛卡尔树。笛卡尔…

P2567 [SCOI2010]幸运数字

P2567 [SCOI2010]幸运数字 题意&#xff1a; 我们规定只含6或8的数字为幸运号码&#xff0c;而幸运号码的倍数我们也认为是幸运号码&#xff0c;问[l,r]中有多少个幸运号码&#xff1f; 题解&#xff1a; 第一反应是数位dp&#xff0c;但其实不是&#xff0c;我们可以打表观…

构建现代Web应用时究竟是选择传统web应用还是SPA

在大前端盛行的今天&#xff0c;似乎前后端分离的开发模式才是大势所趋&#xff0c;而SPA的概念更是应运而生。现在随便构建一个web应用程序如果你不是使用SPA的话&#xff0c;就会感觉有点low&#xff0c;但是真的是这样吗&#xff1f;今天这篇文章我们就来一起探讨下&#xf…

[ZJOI2007] 时态同步(拓扑序)

problem 洛谷链接 solution 结论&#xff1a;使用道具的导线深度越浅越好。 显然&#xff0c;如果有两个终止节点都需要增加 xxx&#xff0c;那么在他们的 lca\text{lca}lca 到根的路径中任意一条边增加 xxx 即可&#xff0c;各自增加 xxx 显然不优。 所以我们不妨倒过来&…

P2571 [SCOI2010]传送带

P2571 [SCOI2010]传送带 题意&#xff1a; 你要从 A 点到 D 点。有两条传送带&#xff1a;第一条从 A 到 B&#xff0c;速度为 pp&#xff0c;第二条从 C 到 D&#xff0c;速度为 q。不走传送带时速度为 r。求从 A 到 D 的最少时间。 题解&#xff1a; 很明显&#xff0c;答…

你所不知道的ASP.NET Core MVC/WebApi基础系列(二)

冒个泡&#xff0c;算起来估计有很长时间没更新公众号了&#xff0c;估计是我第一次停更如此之久&#xff0c;人总有懒惰的时候&#xff0c;时间越长越懒惰&#xff0c;但是呢&#xff0c;不学又不行&#xff0c;持续的惰性是不行dei&#xff0c;要不然会被时光所抛弃&#xff…

[ZJOI2007]报表统计(链表法+set)

problem 洛谷链接 solution 纯纯不理解要搬用平衡树的那些做法&#xff0c;使我们可可爱爱的链表不香不好写吗&#xff1f;&#xff1f; 众所周知&#xff0c;链表法是可以进行删除和增加的&#xff0c;只需要维护每个点的前驱和后继。 相邻两个的差绝对值的最小值&#x…