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. ...
随机推荐
- 天道神诀--samba和NFS部署
samba yum -y install samba samba-client rpm -qa |grep samba service smb start(445端口) service nmb sta ...
- 9-MySQL-Ubuntu-数据表中数据的修改(二)
数据的修改(update) (1)修改整个字段: update 表名 set 字段1=值1,字段2=值2; (2)修改字段部分数据 update 表名 set 字段1=值1,字段2=值2,... wh ...
- ArcGis基础——把类别代码替换成对应中文名称的方法
挂接! 上面是答案,展开一下就是做一个Excel对照表,就两列,代码与中文名称.然后用类别代码字段匹配挂接. 别傻傻找vbs/py代码,不知道拐个弯.
- selenium+plantomJS
#!/usr/bin/env python # -*- coding:utf-8 -*- """ 流程框架: 1.搜索关键词,利用selenium驱动浏览器搜索关键词,查 ...
- day04 mysql单表查询 多表查询 pymysql的使用
day04 mysql pymysql 一.单表查询 1.having过滤 一般用作二次筛选 也可以用作一次筛选(残缺的: 只能筛选select里面 ...
- vue实现京东动态楼层效果
页面效果如下 <template> <div> <h1>首页</h1> <section class="floor-nav" ...
- 常用的Docker镜像及处理命令
常用的镜像命令 docker run -d --name dockerui -p : -v /var/run/docker.sock:/var/run/docker.sock abh1nav/dock ...
- openwrt redis
2071 make V=s 2072 cd build_dir/target-x86_64_uClibc-0.9.33.2/root-x86/ cd package/network/services/ ...
- Webstorm 、ECMAScript 6 、AngularJS
突然接到一智障询问以上内容,大发善心总结(其实就是CV大法)一下下,希望能帮助某智障.....上干活! WebStorm 刚看到我是懵逼的,但是看到和其他两个在一起,猜想到是前台的一开始以为是前台框架 ...
- IDEA使用的JDK版本1.9换成1.8后,在IDEA中需要改的配置
今天上午上课spring5使用注解方式的时候,发现jdk9不兼容,果断换jdk8 步骤如下 一.查看Project中的jdk 1.检查Project SDK:中jdk 版本是否为1.8版本 2.检查P ...