链接:#118. 【UR #8】赴京赶考

高中,高中,短暂的三年。NOI是高中结业考试,而高考在每年暑假举行。

高二暑假,这是你最后一次参加高考的机会。你已经为了高考停课很久了,OI的知识很久没管了。你并没有能力用一年时间补起别人三年的OI课程。这是你的最后一战,如果你失败了,可能就不能工地搬砖只能去清华了。

这天你背上行囊赴京赶考。此时全国交通主要靠瞬间传送装置。全国交通网络可以抽象为一张 nn 行 mm 列的网格图。行依次编号为 ,…,n1,…,n,列依次编号为 ,…,m1,…,m。

有 n+mn+m 个为  或  的整数 a1,…,an,b1,…,bma1,…,an,b1,…,bm。对于 ≤i≤n1≤i≤n,≤j≤m1≤j≤m,如果 ai=bjai=bj 那么网格图上第 ii 行第 jj 列上标着  否则标着 。

你的家在第 xsxs 行第 ysys 列,高考考场在第 xexe 行第 yeye 列。现在你想从家出发到高考考场去。每次你可以:

向上移动一行。(如果你在第一行那么移动后会到最后一行去)
向下移动一行。(如果你在最后一行那么移动后会到第一行去)
向左移动一列。(如果你在第一列那么移动后会到最后一列去)
向右移动一列。(如果你在最后一列那么移动后会到第一列去)
对于每次移动,如果移动前的格子上标的数跟移动后的格子上标的数不同,那么就要耗费 分钟时间等待瞬移装置调整配置,否则不耗时间。 现在你想知道你从家出发到高考考场最少需要花多长时间。 输入格式
第一行两个正整数 n,mn,m,表示网格图为 nn 行 mm 列。 第二行 nn 个整数,分别表示 a1,…,ana1,…,an。保证 a1,…,an∈{,}a1,…,an∈{,}。 第三行 mm 个整数,分别表示 b1,…,bmb1,…,bm。保证 b1,…,bm∈{,}b1,…,bm∈{,}。 接下来一个正整数 qq。 接下来 qq 行,每行四个整数 xs,ys,xe,yexs,ys,xe,ye。表示询问如果你的家在第 xsxs 行第 ysys 列,高考考场在第 xexe 行第 yeye 列时的最少花费时间。 输出格式
共 qq 行,每行一个整数表示最少花费多少分钟。 样例一
input output 样例二
input output 限制与约定
测试点编号 n,mn,m的规模 qq的规模
n,m≤100n,m≤ q≤10q≤ n≤,m=1n≤,m= q≤105q≤ n,m≤105n,m≤ q≤105q≤ 时间限制:1s1s
空间限制:256MB

题干

如果10^5个询问,每次都无脑遍历肯定不行。

想一想横向移动,和纵向移动是互不影响的,那我单独考虑变成两个一维的。

但,10^5次遍历一个10^5的图也还不够。。。

我们又想到可以用个前缀和,表示从第一个位置到当前位置所用的时间

询问时:正着走一遍,倒着走一遍,横纵相加就行。

#include<iostream>
#include<cstdio>
#include<string>
#include<cmath>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<algorithm>
#include<cstring>
using namespace std;
#define LL long long
int n,m,a[],b[],q,xs,ys,xe,ye;
int pre[],pree[];
int work1(int x,int y)
{
if(y>=x)
return pre[y]-pre[x];
return pre[n]-pre[x]+pre[y]+(a[n]^a[]);
}
int work2(int x,int y)
{
if(y>=x)
return pree[y]-pree[x];
return pree[m]-pree[x]+pree[y]+(b[m]^b[]);
}
int main()
{
scanf("%d%d",&n,&m);
scanf("%d",&a[]);
for(int i=;i<=n;i++)
scanf("%d",&a[i]),pre[i]=pre[i-]+(a[i]^a[i-]);
scanf("%d",&b[]);
for(int j=;j<=m;j++)
scanf("%d",&b[j]),pree[j]=pree[j-]+(b[j]^b[j-]); scanf("%d",&q);
for(int i=;i<=q;i++)
{
scanf("%d%d%d%d",&xs,&ys,&xe,&ye);
int t1=min(work1(xs,xe),work1(xe,xs)),t2=min(work2(ys,ye),work2(ye,ys));
printf("%d\n",t1+t2);
}
return ;
}

代码

#118. 【UR #8】赴京赶考的更多相关文章

  1. uoj #118. 【UR #8】赴京赶考 水题

    #118. [UR #8]赴京赶考 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://uoj.ac/problem/118 Description ...

  2. uoj118 【UR #8】赴京赶考

    题目 不难发现我们直接走过去就行了 考虑到第\(i\)行的构造方法就是把\(b\)数组作为模板,每个数和\(a_i\)异或一下就可以了 于是不难发现对于一段连续相等的\(a\),它们在矩阵上就形成了完 ...

  3. UOJ Round #8 赴京赶考 解题报告

    算法零 $n,m \le 100, q \le 10$ 的话,直接给网格中的每一个格点都建一个点,然后该怎么最短路就怎么最短路,该怎么并查集+BFS就怎么并查集+BFS. 复杂度 $O(qnm)$,可 ...

  4. ur c题练习

    ur的c果然sxbk啊 ur5:“三个莫比乌斯反演掷地有声"——摘自v(c)f(z)k(y)语录,无删改 ur2:有根树分治裸题,复杂度玄学$O(n\sqrt{n})$. 首先,转化为统计k ...

  5. db2 with ur

    这几天查询DB2数据库,老遇到select * from XXX with ur, 好奇ur是什么作用,现在记录一下. DB2中,共有四种隔离级:RS,RR,CS,UR,DB2提供了这4种不同的保护级 ...

  6. 【UOJ#33】【UR#2】树上GCD 有根树点分治 + 容斥原理 + 分块

    #33. [UR #2]树上GCD 有一棵$n$个结点的有根树$T$.结点编号为$1…n$,其中根结点为$1$. 树上每条边的长度为$1$.我们用$d(x,y)$表示结点$x,y$在树上的距离,$LC ...

  7. 118. Pascal's Triangle

    题目: Given numRows, generate the first numRows of Pascal's triangle. For example, given numRows = 5, ...

  8. 118. 119. Pascal's Triangle -- 杨辉三角形

    118. Given numRows, generate the first numRows of Pascal's triangle. For example, given numRows = 5, ...

  9. leetcode 118

    118. Pascal's Triangle Given numRows, generate the first numRows of Pascal's triangle. For example, ...

随机推荐

  1. 【转】C#中使用Redis学习二 在.NET4.5中使用redis hash操作

    摘要 上一篇讲述了安装redis客户端和服务器端,也大体地介绍了一下redis.本篇着重讲解.NET4.0 和 .NET4.5中如何使用redis和C# redis操作哈希表.并且会将封装的一些代码贴 ...

  2. package-info.java到底是什么

    发现距离上一次在这里写博客已经三个多月了...说好的笔耕不辍呢=.= Anyway,今天(确切说是昨天晚上)在code review中被组里的QA II问到在一个叫做package-info.java ...

  3. 使用 @RequestMapping 映射请求

  4. Mysql错误: ERROR 1205: Lock wait timeout exceeded; try restarting transaction

    MySQL:innodb的事务锁,一个线程占用着,简单做法是:执行mysql命令: show full processlist; 然后找出查询语句的系统id:kill掉被锁住的线程id:kill 12 ...

  5. sql语句之约束条件

    not null约束,需设置默认值 sex enum('male','female') not null default 'male' unique 约束,值唯一 单列唯一: create table ...

  6. 4-3逻辑非运算符及案例 & 4-4

    创建类 LoginDemo3 这里取反 !(n%3==0) package com.imooc.operator; import java.util.Scanner; public class Log ...

  7. UVa 242 Stamps and Envelope Size (无限背包,DP)

    题意:信封上最多贴S张邮票.有N个邮票集合,每个集合有不同的面值.问哪个集合的最大连续邮资最 大,输出最大连续邮资和集合元素. 最大连续邮资是用S张以内邮票面值凑1,2,3...到n+1凑不出来了,最 ...

  8. 算法学习--Day6

    题目描述 实现一个加法器,使其能够输出a+b的值. 输入描述: 输入包括两个数a和b,其中a和b的位数不超过1000位. 输出描述: 可能有多组测试数据,对于每组数据, 输出a+b的值. 示例1 输入 ...

  9. HTTPS为什么更安全,请看这里

    本文转载于https://foofish.net/https-story-1.html HTTPS 是建立在密码学基础之上的一种安全通信协议,严格来说是基于 HTTP 协议和 SSL/TLS 的组合. ...

  10. ADO学途 five day 连接数据库

    用一个程序的目的就是为了方便对数据进行操作,没有数据的支持,程 序就成了一个空壳子.一般我们常用的数据库有三种mysql, SQL server, Oracle. C#中常用的就是SQL server ...