Luogu P1170 兔八哥与猎人

题目描述

兔八哥躲藏在树林旁边的果园里。果园有M × N棵树,组成一个M行N列的矩阵,水平或垂直相邻的两棵树的距离为1。兔八哥在一棵果树下。

猎人背着猎枪走进了果园,他爬上一棵果树,准备杀死兔八哥。

如果猎人与兔八哥之间没有其它的果树,猎人就可以看到兔八哥。

现己知猎人和兔八哥的位置,编写程序判断兔子所在的位置是否安全.

输入输出格式

输入格式:

第一行为n,表示有n(n ≤ 100,000)组数据,每组数据的第一行为两个正整数ax和ay,表示猎人的位置,第二行为两个正整数bx和by,表示兔八哥的位置(1 ≤ ax, ay, bx, by ≤ 100,000,000)。

输出格式:

共有n行,每行为“yes”或“no”表示兔八哥的位置是否安全。

输入输出样例

输入样例#1:

1
1 1
1 2

输出样例#1:

no

Solution

有陷阱!

第一眼看这道题时,估计很多人与我也一样认为只应判断兔八哥周围八个格(如下图A与B,A与C的关系)是否存在猎人,然而事实并非如此!!!(你们想太少了)

  1. 如图,我们可以很直观的看出其实若猎人在E、F,可怜的兔八哥A可谓在劫难逃,所以我们发现猎人的合理站位不局限于兔八哥周围八个格。
  2. 如图,我们还能知道若猎人在D、G两点兔八哥是安全的,所以我们便要拿这两个点开刀(并与C、E做对比)。
  3. 我们假设兔八哥的坐标是(0,0),则D为(2,2),C为(1,1);G为(-2,-4),E为(-1,-2)。
  4. 我们可以发现兔八哥要想成功躲避猎人,它与猎人横坐标之差的绝对值肯定和它与挡住他(它)们的那棵树横坐标之差的绝对值呈倍数关系,纵坐标亦然(句子有点长,请自行理解)。所以兔八哥要想躲避猎人的攻击,它与猎人横纵坐标之差的绝对值必须同时是一个大于1的整数的倍数,所以它们的最大公约数非1,意思是它们不互质(输出yes)。所以猎人要想杀死兔八哥,自然要将它们互质(输出no)。
  5. 完毕!

——————分割不完全的分割线——————

以下是pascal代码:

var n,m,i,j,k,x1,y1,x2,y2:longint;
function go(x,y:longint):longint;//求最大公约数(辗转相除法)
begin
  if y=0 then
  exit(x)
  else
  go:=go(y,x mod y);
end;
begin
  readln(n);//读入数据组数
  for m:=1 to n do
  begin
    readln(x1,y1);//读入猎人的坐标
    readln(x2,y2);//读入兔八哥的坐标
    if go(abs(x1-x2),abs(y1-y2))=1 then//判断是否互质(最大公约数为1)
    writeln(‘no‘)
    else
    writeln(‘yes‘);
  end;
end.
时间: 2024-12-11 21:41:00

Luogu P1170 兔八哥与猎人的相关文章

洛谷 P1170 兔八哥与猎人

P1170 兔八哥与猎人 题目描述 兔八哥躲藏在树林旁边的果园里.果园有M × N棵树,组成一个M行N列的矩阵,水平或垂直相邻的两棵树的距离为1.兔八哥在一棵果树下. 猎人背着猎枪走进了果园,他爬上一棵果树,准备杀死兔八哥. 如果猎人与兔八哥之间没有其它的果树,猎人就可以看到兔八哥. 现己知猎人和兔八哥的位置,编写程序判断兔子所在的位置是否安全. 输入输出格式 输入格式: 第一行为n,表示有n(n ≤ 100,000)组数据,每组数据的第一行为两个正整数ax和ay,表示猎人的位置,第二行为两个正

P1170 兔八哥与猎人

题目描述 兔八哥躲藏在树林旁边的果园里.果园有M × N棵树,组成一个M行N列的矩阵,水平或垂直相邻的两棵树的距离为1.兔八哥在一棵果树下. 猎人背着猎枪走进了果园,他爬上一棵果树,准备杀死兔八哥. 如果猎人与兔八哥之间没有其它的果树,猎人就可以看到兔八哥. 现己知猎人和兔八哥的位置,编写程序判断兔子所在的位置是否安全. 输入输出格式 输入格式: 第一行为n,表示有n(n ≤ 100,000)组数据,每组数据的第一行为两个正整数ax和ay,表示猎人的位置,第二行为两个正整数bx和by,表示兔八哥

luogu P3799 妖梦拼木棒

二次联通门 : luogu P3799 妖梦拼木棒 /* luogu P3799 妖梦拼木棒 用一个桶存下所有的木棒 美剧两根短的木棒长度 后随便乘一乘就 好了.. */ #include <algorithm> #include <cstdio> #define Mod 1000000007 #define Max 5000 void read (int &now) { now = 0; register char word = getchar (); while (wo

[luogu P1967][NOIp2013]P1967 货车运输

题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下,最多能运多重的货物. 输入输出格式 输入格式: 输入文件名为 truck.in. 输入文件第一行有两个用一个空格隔开的整数 n,m,表示 A 国有 n 座城市和 m 条道 路. 接下来 m 行每行 3 个整数 x. y. z,每两个整数之间用一个空格隔开,表示从 x 号城市到 y 号城市有一条限重为 z

luogu 3126 回文的路径

https://www.luogu.org/problem/show?pid=3126 考虑dp,从两头走到中间. f[i][j][k][l]表示从左上角走到(i,j),从右下角走到(k,l),路径长度相等,所经过路径相同的方案数. 方程不再赘述. 考虑步数要相同,所以只要枚举步数和行就好. f[i][j][k]表示第一个点在第j行,第2个点在第k行,走i步的方案数. 所以得出方程f[i][j][k]=(f[i-1][j-1][k]+f[i-1][j][k+1]+f[i-1][j-1][k+1]

luogu P2018 消息传递

二次联通门 : luogu P2018 消息传递 /* luogu P2018 消息传递 树形dp 原来用优先队列做了一下, T了俩点 MMP 去看正解.. 复杂度一样好不好.. 每次到达一个点,记录其子树中所有的dp值 优先向大的一边转移 */ #include <cstdio> #include <iostream> #include <algorithm> #include <cstring> #define INF 1e8 const int BUF

luogu P1966 火柴排队

二次联通门 : luogu P1966 火柴排队 /* luogu P1966 火柴排队 神TM逆序对... noip怎么这么坑啊.. 暴力都没得打 此题模拟考试时爆了0 做法 将A数组排序,由于B数组与A数组是一一对应的 那么B数组的位置也会发生相应的变化 此时B数组逆序数对数即为答案 */ #include <cstdio> #include <iostream> #include <algorithm> const int BUF = 123123123; cha

luogu P1941 飞扬的小鸟

二次联通门 : luogu P1941 飞扬的小鸟 /* luogu P1941 飞扬的小鸟 dp 向上飞是完全背包,向下掉就是01背包 分情况讨论一下 最后合并一下 */ #include <cstdio> #include <iostream> #include <cstring> const int BUF = 123123123; char Buf[BUF], *buf = Buf; inline void read (int &now) { for (

luogu P2863 [USACO06JAN]牛的舞会The Cow Prom

https://www.luogu.org/problem/show?pid=2863#sub 题目描述 The N (2 <= N <= 10,000) cows are so excited: it's prom night! They are dressed in their finest gowns, complete with corsages and new shoes. They know that tonight they will each try to perform th