列表

详情


NC24854. [USACO 2009 Nov B]The Chivalrous Cow

描述

Farmer John traded one of his cows for a cow that Farmer Don called 'The Knight'. This cow has the unique ability to jump around the pasture in moves that looked like a knight on a chessboard (two squares over, one up... or maybe two squares down and one over, etc.). 'The Knight' can't jump on rocks or trees, but can really make her way around the pasture, which is partitioned for our purposes into an X by Y set of squares (1 <= X <= 150; 1 <= Y <= 150). 'The Knight' likes hay just like any other cow. Given a map of 'The Knight's starting place, locations of the tree, shrub, rock, and other obstacles, and the location of a bale of hay, determine how many 'hops' the Knight must make in order to get to the hay. The Knight cow will be marked by a 'K' on the map; obstacles by '*', and the haybale by 'H'. Here's a typical map:                     11 | . . . . . . . . . .                     10 | . . . . * . . . . .                       9 | . . . . . . . . . .                       8 | . . . * . * . . . .                       7 | . . . . . . . * . .                       6 | . . * . . * . . . H                       5 | * . . . . . . . . .                       4 | . . . * . . . * . .                       3 | . K . . . . . . . .                       2 | . . . * . . . . . *                       1 | . . * . . . . * . .                       0 ----------------------                                            1                         0 1 2 3 4 5 6 7 8 9 0  The knight could travel the path indicated by A, B, C, ... to get to the hay bale in just 5 moves (other routes of length 5 might be possible):                     11 | . . . . . . . . . .                     10 | . . . . * . . . . .                      9 | . . . . . . . . . .                      8 | . . . * . * . . . .                      7 | . . . . . . . * . .                      6 | . . * . . * . . . F<                      5 | * . B . . . . . . .                      4 | . . . * C . . * E .                      3 | .>A . . . . D . . .                      2 | . . . * . . . . . *                      1 | . . * . . . . * . .                      0 ----------------------                                            1                        0 1 2 3 4 5 6 7 8 9 0  Hint: This problem is probably most easily solved with a simple first-in/first-out 'queue' data structure implemented as a few parallel arrays.

输入描述

* Line 1: Two space-separated integers: X and Y

* Lines 2..Y+1: Line Y-i+2 contains X characters with no spaces (i.e., the map is read in as shown in the text above): map row i

输出描述

* Line 1: A single integer that is the minimum number of hops to get to the hay bale. It is always possible to get to the haybale.

示例1

输入:

10 11
..........
....*.....
..........
...*.*....
.......*..
..*..*...H
*.........
...*...*..
.K........
...*.....*
..*....*..

输出:

5

原站题解

上次编辑到这里,代码来自缓存 点击恢复默认模板

C++(clang++11) 解法, 执行用时: 9ms, 内存消耗: 760K, 提交时间: 2021-02-09 19:08:59

#include<algorithm>
#include<iostream>
#include<cstring>
#include<string>
#include<cstdio>
#include<cmath>
using namespace std;
int q[40010][3],f[210][210],dx[8]={-1,-1,1,1,-2,-2,2,2},dy[8]={-2,2,-2,2,-1,1,-1,1};
char ch[210][210];
int main()
{
	int n,m,a1,b1;
	cin>>m>>n;
	for(int i=1;i<=n;i++)
	for(int j=1;j<=m;j++)
	{
		cin>>ch[i][j];
		if(ch[i][j]=='K')
		{
			q[1][0]=i;
			q[1][1]=j;
		}
		if(ch[i][j]=='H')
		{
			a1=i;
			b1=j;
		}
	}
	int s=0,w=1;
	while(s<w)
	{
		s++;
		int x=q[s][0],y=q[s][1],z=q[s][2];
		if(x==a1&&y==b1)
		{
			cout<<z<<"\n";
			return 0;
		}
		for(int i=0;i<8;i++)
	    {
	    	int a2=x+dx[i],b2=y+dy[i];
	    	if(a2<1||b2<1||a2>n||b2>m||ch[a2][b2]=='*'||f[a2][b2])
	    	continue;
	    	w++;
	    	q[w][0]=a2;
	    	q[w][1]=b2;
	    	q[w][2]=z+1;
	    	f[a2][b2]=true;
		}
	}
	return 0;
	
}

C++14(g++5.4) 解法, 执行用时: 3ms, 内存消耗: 628K, 提交时间: 2019-08-25 11:34:26

#include<bits/stdc++.h>
using namespace std;
const int dx[]={-2,-2,-1,-1,1,1,2,2},dy[]={-1,1,-2,2,-2,2,-1,1};
int n,m,i,j,k,d[155][155],qx[30005],qy[30005],he,ta;
char c[155][155];
int main()
{
    scanf("%d%d",&m,&n);
    for(i=1;i<=n;i++)scanf("%s",c[i]+1);
    memset(d,-1,sizeof(d));
    for(i=1;i<=n;i++)for(j=1;j<=n;j++)if(c[i][j]=='K')
    {
        d[qx[ta]=i][qy[ta]=j]=0;
        ta++;
    }
    while(he!=ta)
    {
        i=qx[he];
        j=qy[he++];
        for(k=0;k<8;k++)if(i+dx[k]>0&&i+dx[k]<=n&&j+dy[k]>0&&j+dy[k]<=m&&c[i+dx[k]][j+dy[k]]!='*'&&!~d[i+dx[k]][j+dy[k]])
        {
            d[qx[ta]=i+dx[k]][qy[ta]=j+dy[k]]=d[i][j]+1;
            ta++;
        }
    }
    for(i=1;i<=n;i++)for(j=1;j<=m;j++)if(c[i][j]=='H')cout<<d[i][j]<<endl;
    return 0;
}

上一题