CF538G Berserk Robot
题意:一个机器人在一个无穷大的网格图中,每秒能够上下左右走一步。它的行走方向序列是长度为l的循环。给你n个线索,包括ti:时间,xi,yi走到的坐标。让你构造出行走的方向序列?
标程:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=;
ll t,x,y,nx,ny;
int n,l[N],r[N],len;
struct node{ll ty,tz,x;node(){} node(ll A,ll B,ll C){ty=A;tz=B;x=C;}}a[N],b[N];
bool operator < (const node &A,const node &B) {return A.ty<B.ty;}
ll ceil(ll x,ll y)
{
if (x<) x=-x,y=-y;
if (x==) return ;
if (y>) return (x-)/y+;
else return x/y;
}
ll floor(ll x,ll y)
{
if (x<) x=-x,y=-y;
if (x==) return ;
if (y>) return x/y;
else return (x-)/y-;
}
void solve(node *a,int *ans)
{
sort(a+,a+n+);
ll L=,R=len;
a[n+]=node(len,-,);//设置边界!!!
for (int i=;i<=n;i++)//要统计入最后一个限制S[len]=0-S*(-1)
{
ll d=a[i+].ty-a[i].ty,q=a[i+].x-a[i].x,p=a[i].tz-a[i+].tz;
if (p>)
{
L=max(L,ceil(-q,p));
R=min(R,floor(d-q,p));
}else if (p<) {
L=max(L,ceil(d-q,p));
R=min(R,floor(-q,p));
}
if (L>R||p==&&(q<||q>d)) {puts("NO");exit();}
}
ll s=L,si=;
for (int i=,j=;i<=n;i++)
{
si=(a[i+].x-s*a[i+].tz)-(a[i].x-s*a[i].tz);
while (si--) ans[j++]=;
j=a[i+].ty+;//a[i+1]而不是a[i]
}
}
int main()
{
scanf("%d%d",&n,&len);
for (int i=;i<=n;i++)
{
scanf("%lld%lld%lld",&t,&x,&y);
nx=x+y+t;ny=x-y+t;
if (nx&) return puts("NO"),;
nx/=;ny/=;
a[i]=node(t%len,t/len,nx);
b[i]=node(t%len,t/len,ny);
}
solve(a,l);
solve(b,r);
for (int i=;i<=len;i++)
printf("%c","LDUR"[l[i]<<|r[i]]);//此题的方向与常识相异!
return ;
}
易错点:1.注意设置l处的边界,要统计入最后一个限制S[len]=0-S*(-1),否则不等式不完整。
2.注意负数和0的上下取整。
题解:转换+不等式构造
这道题思路非常喵!
将x,y坐标分开考虑,每次x坐标+-1,或y坐标+-1。难以处理。
设置(x+y,x-y)为新的参数,这样每次两个参数都会有+-1的变化。
再进一步,((x+y+t)/2,(x-y+t)/2)设置,每次要么+1,要么+0。
——以上是坐标和时间结合题的某种套路。
之后就是构造合法解的事情了。
这样对于一系列的t,由于l是循环节长度,设Sl为单位循环加了多少个1,S[i]表示i时间内加了多少个1,可以列出等式S[t%l]=Xi-Sl*[t/l]。
以及由相邻依次递增的t%i列出一系列不等式:0<=Sb-Sa<=b-a。整体化成0<=p*Sl+q<=d的形式,可以解出Sl的取值范围,取范围中的任意值皆可。
这样可以解出所有S[t%l],直接按区间填上对应数量的1即可。
CF538G Berserk Robot的更多相关文章
- Codeforces 538G - Berserk Robot(乱搞)
Codeforces 题目传送门 & 洛谷题目传送门 一道很神的乱搞题 %%% 首先注意到如果直接去做,横纵坐标有关联,不好搞.这里有一个非常套路的技巧--坐标轴旋转,我们不妨将整个坐标系旋转 ...
- Robot Framework用户手册 (版本:3.0)
版权信息:诺基亚网络和解决中心 本翻译尊重原协议,仅用于个人学习使用 1.开始: 1.1 介绍: Robot Framework是一个基于Python的,为终端测试和验收驱动开发(ATDD)的可扩展的 ...
- selenium webdriver 右键另存为下载文件(结合robot and autoIt)
首先感谢Lakshay Sharma 大神的指导 最近一直在研究selenium webdriver右键菜单,发现selenium webdriver 无法操作浏览器右键菜单,如图 如果我想右键另存为 ...
- RIDE -- Robot Framework setup
RobotFramework 是一款基于python 的可以实现关键字驱动和数据驱动并能够生成比较漂亮的测试报告的一款测试框架 这里使用的环境是 python-2.7.10.amd64.msi RID ...
- [8.2] Robot in a Grid
Imagine a robot sitting on the upper left corner of grid with r rows and c columns. The robot can on ...
- Robot Framework自动化测试 ---视频与教程免费分享
当我第一次使用Robot Framework时,我是拒绝的.我跟老大说,我拒绝其实对于习惯了代码的自由,所以讨厌这种“填表格”式的脚本.老大说,Robot Framework使用简单,类库丰富,还可以 ...
- robot创建桌面图标(转载)
桌面ride图标,安装之后会自动创建(偶尔也会创建失败),创建桌面图标方法如下: 1. 新建快捷方式 在桌面右击鼠标,弹出的菜单选择 新建-快捷方式 ,然后在"请键入对象"的位置输 ...
- Robot Framework 的安装和配置(转载)
Robot Framework 的安装和配置 在使用 RF(Rebot framework)的时候需要 Python 或 Jython 环境,具体可根据自己的需求来确定.本文以在有 Python 的环 ...
- 解决从jenkins打开robot framework报告会提示‘Opening Robot Framework log failed ’的问题
最新的jenkins打开jenkins robot framework报告会提示如下 Verify that you have JavaScript enabled in your browser. ...
随机推荐
- echarts的图表根据父容器大小的改变而改变(弹窗easy-ui的window窗口)
1.echarts的图表只绘制一次,所以要想大小随着父容器变化就得调方法重新绘制.所以把绘制图表的方法提出来. <div class="echart"> <div ...
- 在 Keil uVision4 MDK下配置开发STM32F103Z完整教程
转载的,请原作者勿怪,以下为原链接: http://www.51hei.com/bbs/dpj-30359-1.html(欢迎直接查看原作者) 环境搭建: 1.安装 Keil uVision4 MDK ...
- Tomcat7安装和配置以及优化
安装Tomcat7 下载安装方法一: 直接下载Tomcat7: wget http://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-7/v7.0 ...
- CentOS7-安装最新版本GIT(git version 2.18.0)
Git安装方式有两种一种是yum安装一种是编译安装: 一.yum命令安装,此方法简单,会自动安装依赖的包,而且会从源里安装最新的版本,如果仓库不是最新的话安装的也不是最新Git. sudo yum i ...
- leetcood学习笔记-206-反转链表
题目描述: 最佳解: class Solution(object): def reverseList(self, head): """ :type head: ListN ...
- delphi 文件存取方法与文件管理组件
9.2 文件存取方法与文件管理组件 9.2.1 存取文件的类方法 Delphi在许多需要与文件打交道的类中定义了文件存取方法,使用这些方法可以非常方便地将类中的数据保存到文件中,或从文件中读取所需 ...
- Perl 循环
Perl 循环 有的时候,我们可能需要多次执行同一块代码.一般情况下,语句是按顺序执行的:函数中的第一个语句先执行,接着是第二个语句,依此类推. 编程语言提供了更为复杂执行路径的多种控制结构. 循环语 ...
- mysql利用st_distance函数查询附近的点的功能
随着近几年各类移动终端的迅速普及,在手机移动定位app中,附近的人,附近的地点功能十分常见,基于地理位置的服务(LBS)和相关应用也越来越多,而支撑这些应用的最基础技术之一,就是基于地理位置信息的处理 ...
- javafx教程大全
链接: https://www.yiibai.com/javafx
- zookeeper3台机器集群环境的搭建
三台机器zookeeper的集群环境搭建 Zookeeper 集群搭建指的是 ZooKeeper 分布式模式安装. 通常由 2n+1台 servers 组成. 这是因为为了保证 Leader 选举(基 ...