ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

AT4432 [ARC103B] Robot Arms 题解

2021-11-05 23:01:41  阅读:133  来源: 互联网

标签:now ch int 题解 Robot len 步长 ret ARC103B


题目大意

初始在 \((0,0)\) 点,有 \(n\) 组数据,需要在走 \(m\) 步后到达,\((x_i,y_i)\),每组的步长相同,每步的方向可以任意

要求构造一种合法方案

AT4432 [ARC103B] Robot Arms

solve

先判断是否无解,显然,对于每组数据,走完后的 \(x_i+y_i\)的奇偶性是不变的,所以如果 \(x_i+y_i\) 的奇偶性不同的话就无解

然后考虑如何构造步长

通过观察我们发现,\(m\) 最大只有 \(40\) 左右,所以考虑二进制拆分坐标

也就是说,我们要用 \(1,2,4,...,2^k\) 的步长来构造

显然,四个象限是等价的,所以只需要考虑第一象限,发现对于 \(\{1,2,4\cdots 2^k\}\),它可以维护到的位置至少是所有 \(|x+y|=\sum _{i=0}^k 2^i=2^{k+1}-1\),

如果可以正负的话,那么可以访问到的格子久变成了 |\(x+y| - \sum 2^p\)

所以构造方法就很显然了

反过来思考,从大到小放,如果 \(x\) 坐标的偏移量大就放 \(x\),如果 \(y\)坐标的偏移量大就放 \(y\) ,那么肯定能存在一种构造方式

code

#include<bits/stdc++.h>
using namespace std;
const int maxn=1010;
int N,x[maxn],y[maxn],tmp,n;
typedef long long LL;
LL len[40];
char s[40];
inline int read(){
	int ret=0,f=1;char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-f;ch=getchar();}
	while(ch<='9'&&ch>='0')ret=ret*10+ch-'0',ch=getchar();
	return ret*f;
}
int main(){
	N=read();n=N;
	for(int i=1;i<=N;i++)x[i]=read(),y[i]=read();
	tmp=abs(x[1]+y[1])&1;
	for(int i=2;i<=N;i++){
		if((abs((x[i]+y[i])&1))!=tmp) return printf("%d\n",-1),0;
	}
	printf("%d\n1 ",32-tmp);len[1]=1;N=1;
	if(!tmp)for(int i=0;i<=30;i++)printf("%d ",len[++N]=1<<i);
	else for(int i=1;i<=30;i++)printf("%d ",len[++N]=1<<i);
	printf("\n");
	for(int i=1;i<=n;i++){
		LL now_x=0,now_y=0;
		memset(s,0,sizeof s);
		for(int j=N;j;j--){
			LL dx=x[i]-now_x,dy=y[i]-now_y;
			if(abs(dx)>abs(dy)){
				if(dx>0)now_x+=len[j],s[j]='R';
				else now_x-=len[j],s[j]='L';
			}
			else {
				if(dy>0)now_y+=len[j],s[j]='U';
				else now_y-=len[j],s[j]='D';
			}
		}
		printf("%s\n",s+1);
	}
	return 0;
}

标签:now,ch,int,题解,Robot,len,步长,ret,ARC103B
来源: https://www.cnblogs.com/martian148/p/15515586.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有