[USACO07DEC]Mud Puddles S

yizhihongxing

[USACO07DEC]Mud Puddles S

题目描述

Farmer John is leaving his house promptly at 6 AM for his daily milking of Bessie. However, the previous evening saw a heavy rain, and the fields are quite muddy. FJ starts at the point (0, 0) in the coordinate plane and heads toward Bessie who is located at (X, Y) (-500 ≤ X ≤ 500; -500 ≤ Y ≤ 500). He can see all N (1 ≤ N ≤ 10,000) puddles of mud, located at points (Ai, Bi) (-500 ≤ Ai ≤ 500; -500 ≤ Bi ≤ 500) on the field. Each puddle occupies only the point it is on.

Having just bought new boots, Farmer John absolutely does not want to dirty them by stepping in a puddle, but he also wants to get to Bessie as quickly as possible. He's already late because he had to count all the puddles. If Farmer John can only travel parallel to the axes and turn at points with integer coordinates, what is the shortest distance he must travel to reach Bessie and keep his boots clean? There will always be a path without mud that Farmer John can take to reach Bessie.

清早6:00,Farmer John就离开了他的屋子,开始了他的例行工作:为贝茜挤奶。前一天晚上,整个农场刚经受过一场瓢泼大雨的洗礼,于是不难想见,FJ 现在面对的是一大片泥泞的土地。FJ的屋子在平面坐标\((0, 0)\)的位置,贝茜所在的牛棚则位于坐标\((X,Y)\) \((-500 <= X <= 500; -500 <= Y <= 500)\)处。当然咯, FJ也看到了地上的所有N(1 <= N <= 10,000)个泥塘,第i个泥塘的坐标为 \((A\_i, B\_i)\) \((-500 <= A\_i <= 500;-500 <= B\_i <= 500)\)。每个泥塘都只占据了它所在的那个格子。 Farmer John自然不愿意弄脏他新买的靴子,但他同时想尽快到达贝茜所在的位置。为了数那些讨厌的泥塘,他已经耽搁了一些时间了。如果Farmer John 只能平行于坐标轴移动,并且只在x、y均为整数的坐标处转弯,那么他从屋子门口出发,最少要走多少路才能到贝茜所在的牛棚呢?你可以认为从FJ的屋子到牛棚总是存在至少一条不经过任何泥塘的路径。

输入格式

* Line 1: Three space-separate integers: X, Y, and N.

第1行: 3个用空格隔开的整数:X,Y 和 N

* Lines 2..N+1: Line i+1 contains two space-separated integers: Ai and Bi

第2..N+1行: 第i+1行为2个用空格隔开的整数:A_i 和 B_i

输出格式

* Line 1: The minimum distance that Farmer John has to travel to reach Bessie without stepping in mud.

第1行: 输出1个整数,即FJ在不踏进泥塘的情况下,到达贝茜所在牛棚所需要 走过的最小距离

样例

样例输入

1 2 7
0 2
-1 3
3 1
1 1
4 2
-1 1
2 2

样例输出

11



代码

#include <bits/stdc++.h>
using namespace std;
struct Node{
	int x,y,dis;
};
queue<Node> q;
bool m[1001][1001];
int x,y,n;
const int dx[4]={-1,0,1,0};
const int dy[4]={0,1,0,-1};
bool f(int x,int y)
{
	return x<-500||x>500||y<-500||y>500||m[x+500][y+500];
}
void bfs()
{
	q.push({0,0,0});
	while(!q.empty())
	{
		int nx=q.front().x,ny=q.front().y,val=q.front().dis;
		q.pop();
		if(f(nx,ny)) continue;
		m[nx+500][ny+500]=1;
		if(nx==x&&ny==y)
		{
			cout << val << endl;
			return;
		}
		for(int i=0;i<4;i++)
		{
			q.push({nx+dx[i],ny+dy[i],val+1});
		}
	}
}
int main()
{
	cin >> x >> y >> n;
	while(n--)
	{
		int X,Y;
		cin >> X >> Y;
		m[X+500][Y+500]=1;
	}
	bfs();
	return 0;
}

原文链接:https://www.cnblogs.com/momotrace/p/p2873.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:[USACO07DEC]Mud Puddles S - Python技术站

(0)
上一篇 2023年4月27日
下一篇 2023年4月27日

相关文章

  • C语言中如何进行跨平台开发?

    C语言是一种跨平台编程语言,因为它的编译器可以在不同的操作系统上进行编译。然而,由于操作系统本身的不同,开发跨平台应用程序的过程可能会涉及不同的挑战。以下是C语言进行跨平台开发的完整攻略: 选择跨平台的库和框架 一些跨平台库和框架可以帮助开发者更轻松地在不同平台之间移植代码,避免特定于平台的依赖关系。例如,QT是一个开源跨平台GUI框架,可以用于开发Wind…

    C 2023年4月27日
    00
  • C语言中打印特殊图案的实现代码

    下面是详细讲解“C语言中打印特殊图案的实现代码”的完整攻略。 1. 基本概念 在C语言中,我们可以通过使用转义字符来实现打印特殊字符或图案的功能。转义字符是以反斜杠(\)开头的一种特殊字符,它们表示某些无法输入的字符,如换行符、制表符、回车符等。 2. 实现代码 2.1 示例一:打印三角形 以下代码可以打印一个由星号组成的三角形,可以通过连续打印多行来实现。…

    C 2023年5月24日
    00
  • C 程序 二进制转换为十进制

    C程序 二进制转换为十进制使用攻略 1. 程序说明 本程序是用C语言编写的二进制转十进制的代码。它能够将一个二进制数转为与之对应的十进制数。 2. 程序使用 2.1 代码说明 程序主要包含了两个部分:函数定义和函数调用。其中函数定义部分包括二进制转十进制的核心函数binaryToDecimal(),该函数的详细定义和使用说明如下: int binaryToD…

    C 2023年5月9日
    00
  • php json_encode()函数返回json数据实例代码

    下面是关于php json_encode()函数返回json数据实例代码的详细攻略: 1. json_encode()函数简介 json_encode()函数是PHP内置的一个函数,是将PHP变量转换为JSON格式的字符串的常用方法。在实际开发中,通过该函数将PHP数组、对象等数据类型转换为JSON格式后,可以通过Ajax技术在前端页面实现异步数据传输。 2…

    C 2023年5月23日
    00
  • postgresql 实现修改jsonb字段中的某一个值

    要实现修改 jsonb 字段中的某一个值,可以使用 PostgreSQL 提供的相关函数来实现。下面我会详细讲解如何使用 PostgreSQL 的函数来实现修改 jsonb 字段。 准备工作 首先,我们需要创建一个包含 jsonb 字段的表来演示。可以使用下面的 SQL 语句创建新表: CREATE TABLE example ( id SERIAL PRI…

    C 2023年5月23日
    00
  • Maplesoft Maple 2019安装许可激活+Update升级教程图文详解(附下载)

    下面我将详细讲解“Maplesoft Maple 2019安装许可激活+Update升级教程图文详解(附下载)”的完整攻略。 Maplesoft Maple 2019安装许可激活+Update升级教程图文详解(附下载) Maplesoft Maple 2019是一款非常优秀的数学软件,在数学建模、图像绘制、符号计算等方面具有非常出色的表现。本文将为大家详细介…

    C 2023年5月22日
    00
  • 网络基础版各种命令行集锦

    我来为你详细讲解一下“网络基础版各种命令行集锦”的攻略。 网络基础版各种命令行集锦 简介 在网络相关工作或学习中,命令行的使用是必不可少的一部分。本文以Linux系统为例,介绍一些常见的网络命令行操作,帮助读者更好地理解和掌握命令行的使用方法。 网络基础命令 ifconfig ifconfig命令用于配置和显示网络接口的信息。在终端中输入ifconfig后,…

    C 2023年5月22日
    00
  • C语言编程银行ATM存取款系统实现源码

    C语言编程银行ATM存取款系统实现源码攻略 背景介绍 随着现金支付逐渐落后于时代的步伐,银行ATM机成为了人们日常生活中不可或缺的一部分。银行ATM机内置了众多功能,例如可以查询余额、转账、存取款等,其中存取款是最为基本且常用的功能。 实现源码攻略 在实现ATM机的存取款系统时,我们可以采用C语言进行编程,以下是实现源码的攻略: 确定目标 在进行ATM机的编…

    C 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部