当前位置: 首页 > news >正文

RainbowDash 的 Robot

H RainbowDash 的 Robot - 第七届校赛正式赛 —— 补题

题目大意:

给一个 n ∗ m n*m nm 的二维网格,在第 i i i 列中,前 a i a_i ai 单元格被阻断,无法通行,即 [ 1 , a i ] [1,a_i] [1,ai]

一个机器人正在这个网格内移动,你可以向他发送指令,使得其向 上下左右 移动,但是这个机器人是由缺陷的,每条指令会执行 k k k 次,因此,机器人每次移动 k k k 个单元格,如果机器人试图移动到受阻的单元格或网格外,就会爆炸。

q q q 次询问,每次询问都有一个起始单元格 s x , s y sx,sy sx,sy ,一个终点单元格 f x , f y fx,fy fx,fy 和一个值 k k k

若机器人执行任意次命令,能否从起点单元到达终点单元

1 < = n < = 1 0 9 , 1 < = m < = 2 ∗ 1 0 5 1<=n<=10^9,1<=m<=2*10^5 1<=n<=109,1<=m<=2105

0 < = a i < = n 0<=a_i<=n 0<=ai<=n

1 < = q < = 2 ∗ 1 0 5 1<=q<=2*10^5 1<=q<=2105

1 < = k < = 1 0 9 1<=k<=10^9 1<=k<=109

保证起点坐标和终点坐标有效

思路:

优先考虑机器人从起点坐标走到终点坐标需要满足的条件,

s x sx sx f x fx fx 之间距离必须是 k k k 的倍数, s y sy sy f y fy fy 之间距离必须是 k k k 的倍数

if( llabs(sx-fx)%k!=0 || llabs(sy-fy) ){
	cout<<"No\n";
	continue;
}

满足以上条件之后,考虑从 s y sy sy 到达 f y fy fy ,需要满足之间没有受阻的网格,所以贪心的想,优先走到该列最下面,再往左右走,考虑从第 s y sy sy f y fy fy 之间最大的受阻网格为多少即可,数据范围较大,维护区间最值可选用线段树 。

int len=sx+(n-sx)/k*k;
auto x=query(1,1,m,min(sy,fy),max(sy,fy));
if(x.mx>=len){
	cout<<"No\n";
}else{
	cout<<"Yes\n";
}

代码:

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define fi first
#define se second
#define PII pair<int,int>
#define lowbit(x) x&-x
#define ALL(x) x.begin(),x.end()

const int mod = 1e9 + 7;
const int N = 1e6 + 10;

int a[N];
struct node
{
	int lz;
	int mx;
}tr[N*4];

node push_up(node L,node R)
{
	node res={0,0};
	res.mx=max(L.mx,R.mx);
	return res; 
}

void build(int p,int l,int r)
{
	if(l==r){
		tr[p].mx=a[l];
		return ;
	}
	int mid=l+r>>1;
	build(p*2,l,mid);
	build(p*2+1,mid+1,r);
	tr[p]=push_up(tr[p*2],tr[p*2+1]);
}

node query(int p,int l,int r,int L,int R)
{
	if(L<=l&&r<=R){
		return tr[p];
	}
	node res={0,0};
	int mid=l+r>>1;
	if(L<=mid) res=push_up(res,query(p*2,l,mid,L,R));
	if(R>mid) res=push_up(res,query(p*2+1,mid+1,r,L,R));
	return res;
}

void solve() {
	int n,m;cin>>n>>m;
	for(int i=1;i<=m;i++){
		cin>>a[i];
	}	
	build(1,1,m);
	int q;cin>>q;
	while(q--){
		int sx,sy,fx,fy,k;cin>>sx>>sy>>fx>>fy>>k;
		if(llabs(sx-fx)%k!=0||llabs(sy-fy)%k!=0){
			cout<<"No\n";
			continue;
		}
		auto x=query(1,1,m,min(sy,fy),max(sy,fy));
		int len=sx+(n-sx)/k*k;
//		cout<<x.mx<<" "<<len<<'\n';
		if(x.mx>=len){
			cout<<"No\n";
		}else{
			cout<<"Yes\n";
		}
	}
}

signed main() {
	std::ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	int T = 1;
//	cin >> T;
	while (T--) {
		solve();
	}
	return 0;
}
http://www.dtcms.com/a/108345.html

相关文章:

  • C++学习笔记(三十一)——map
  • Git的基础使用方法
  • 微信小程序唤起app
  • 【Docker】使用Docker快速部署n8n和unclecode/crawl4ai
  • PEFT实战(一)——LoRA
  • 大模型学习一:deepseek api 调用实战以及参数介绍
  • 【动手学深度学习】#7 现代卷积神经网络
  • C++多态:从青铜九鼎到虚函数表的千年演化密码
  • Pytorch|RNN-心脏病预测
  • 文件分享系统--使用AI Trae开发前后端
  • 鸿蒙应用元服务开发-Account Kit获取华为账号用户信息概述
  • 魔塔社区使用llamafactory微调AI阅卷试题系统
  • 应用弥散张量成像和支持向量机检测慢性爆炸相关轻度颅脑损伤
  • Dockerfile文件构建镜像Anaconda+Python教程
  • 六十天Linux从0到项目搭建(第十八十九天)(缓冲区机制、未打开的磁盘存放、文件存储、磁盘物理结构、寻址、块设备管理、文件系统、增删查改、硬链接、软链接)
  • 通俗易懂的解释Git操作中“合并”和“变基”的区别
  • CMD命令通过已知ip使用以下三种方式来获取对方主机名
  • 常见优化SQL语句策略和示例
  • ControlNet-Tile详解
  • 最新Spring Security实战教程(八)Remember-Me实现原理 - 持久化令牌与安全存储方案
  • Python数据可视化-第3章-图表辅助元素的定制
  • PyTorch 中池化层MaxPool2d
  • CSS--解决float: right在空间不够时会自动往下移的问题
  • 音视频入门基础:MPEG2-TS专题(26)——通过FFmpeg命令使用RTP发送TS流
  • 【Word】批注一键导出:VBA 宏
  • C#核心学习(五)面向对象--封装(4)C#中的索引器详解:让对象像数组一样灵活访问
  • MySQL的数据目录以及日志
  • 企业网络优化方案:SD-WAN赋能企业远程办公
  • 使用JSON.stringify报错:Uncaught TypeError: cyclic object value
  • RNN模型与NLP应用——(6/9)Text Generation(文本自动生成)