usaco The Tamworth Two

john和牛在二维的图里面跑,john要抓住牛。

牛和john在遇到墙或者图的边界时都会花一单位的时间顺时针转动90度。否则花一单位时间往前走一格,当牛和john走到同一个格子中时,john抓住了牛。

求john抓住牛要多久。抓不住时输出0.

一开始想了很久如何判断抓不住的情况,相通了之后还是很简单的。

john和牛都走到了以前走到位置,且保持着以前相同的方向。则说明陷入了循环(再也抓不住了)

/*
ID: modengd1
PROG: ttwo
LANG: C++
*/
#include <iostream>
#include <stdio.h>
#include <memory.h>
int dx[4]={-1,0,1,0};
int dy[4]={0,1,0,-1};
using namespace std;
bool vis[10][10][4][10][10][4];
char input[10][10];
struct position
{
    pair<int,int> P;
    int dir;
};
void Move(position& x)
{
    //装墙或者出地图
    int nextX=x.P.first+dx[x.dir],nextY=x.P.second+dy[x.dir];
    if(input[nextX][nextY]==‘*‘||nextX<0||nextX>9||nextY<0||nextY>9)
    {
        x.dir=(x.dir+1)%4;
        return ;
    }
    //往前走
    x.P.first=nextX;
    x.P.second=nextY;
}
int main()
{
    freopen("ttwo.in","r",stdin);
    freopen("ttwo.out","w",stdout);
    position john,cow;
    memset(vis,false,sizeof(vis));
    for(int i=0;i<10;i++)
    {
        for(int j=0;j<10;j++)
        {
            scanf("%c",&input[i][j]);
            if(input[i][j]==‘F‘)
            {
                john.P.first=i;
                john.P.second=j;
                john.dir=0;
            }
            else if(input[i][j]==‘C‘)
            {
                cow.P.first=i;
                cow.P.second=j;
                cow.dir=0;
            }
        }
        getchar();
    }
    int ans=0;
    position& J=john;
    position& C=cow;
    while(true)
    {
        if(john.P.first==cow.P.first&&john.P.second==cow.P.second)
            break;
        if(vis[john.P.first][john.P.second][john.dir][cow.P.first][cow.P.second][cow.dir])
        {
            ans=0;
            break;
        }
        vis[john.P.first][john.P.second][john.dir][cow.P.first][cow.P.second][cow.dir]=true;
        Move(J);
        Move(C);
        ans++;
    }
    cout<<ans<<endl;
    return 0;
}

  

时间: 2024-10-19 18:24:37

usaco The Tamworth Two的相关文章

USACO The Tamworth Two 模拟

一道模拟题不过要担心的是牛或者人在转弯的时候,另一方如果能走,那么要走,不能停留. 还是蛮简单的. 调试输出的话可以看到具体追击过程 Source Code: /* ID: wushuai2 PROG: ttwo LANG: C++ */ //#pragma comment(linker, "/STACK:16777216") //for c++ Compiler #include <stdio.h> #include <iostream> #include &

洛谷P1518 两只塔姆沃斯牛 The Tamworth Two

P1518 两只塔姆沃斯牛 The Tamworth Two 109通过 184提交 题目提供者该用户不存在 标签USACO 难度普及+/提高 提交  讨论  题解 最新讨论 求数据 题目背景 题目描述 两只牛逃跑到了森林里.农夫John开始用他的专家技术追捕这两头牛.你的任务是模拟他们的行为(牛和John). 追击在10x10的平面网格内进行.一个格子可以是: 一个障碍物, 两头牛(它们总在一起), 或者 农民John. 两头牛和农民John可以在同一个格子内(当他们相遇时),但是他们都不能进

USACO 2.4

USACO 2.4.1 题解: 模拟. 用一个6维数组储存农夫与奶牛当前状态是否出现过,若出现过则表明出现循环,直接输出0,f[农夫x][农夫y][农夫方向][奶牛x][奶牛y][奶牛方向]. 最后注意转弯要算一步. 代码: /* ID:m1599491 PROB:ttwo LANG:C++ */ #include<cmath> #include<cstdio> #include<cstring> #include<iostream> using names

COGS 696. [IOI1996][USACO 2.3] 最长前缀

★   输入文件:prefix.in   输出文件:prefix.out   简单对比时间限制:1 s   内存限制:128 MB 描述 USACO 2.3.1 IOI96 在生物学中,一些生物的结构是用包含其要素的大写字母序列来表示的.生物学家对于把长的序列分解成较短的序列(即元素)很感兴趣. 如果一个集合 P 中的元素可以通过串联(元素可以重复使用,相当于 Pascal 中的 “+” 运算符)组成一个序列 S ,那么我们认为序列 S 可以分解为 P 中的元素.元素不一定要全部出现(如下例中B

USACO prefix TrieTree + DP

/* ID:kevin_s1 PROG:prefix LANG:C++ */ #include <iostream> #include <cstdio> #include <string> #include <cstring> #include <vector> #include <map> #include <set> #include <algorithm> #include <cstdlib>

【USACO 1.3.4】牛式

[題目描述 ] 下面是一个乘法竖式,如果用我们给定的那n个数字来取代*,可以使式子成立的话,我们就叫这个式子牛式. * * * x * * ---------- * * * * * * ---------- * * * * 数字只能取代*,当然第一位不能为0,况且给定的数字里不包括0. 注意一下在美国的学校中教的"部分乘积",第一部分乘积是第二个数的个位和第一个数的积,第二部分乘积是第二个数的十位和第一个数的乘积. 写一个程序找出所有的牛式. [格式] INPUT FORMAT: (f

USACO Chapter 1 Section 1.1

USACO的题解和翻译已经很多了... 我只是把自己刷的代码保存一下. 1.PROB Your Ride Is Here 1 /* 2 ID:xiekeyi1 3 PROG:ride 4 LANG:C++ 5 */ 6 7 #include<bits/stdc++.h> 8 using namespace std ; 9 10 int main() 11 { 12 freopen("ride.in","r",stdin); 13 freopen(&quo

USACO Your Ride Is Here

[USACO]Your Ride Is Here It is a well-known fact that behind every good comet is a UFO. These UFOs often come to collect loyal supporters from here on Earth. Unfortunately, they only have room to pick up one group of followers on each trip. They do,

usaco月赛,2017.1总结

T1:跳舞的奶牛 大致题意:一个体积为k的舞台能够同时容纳k只奶牛一起跳舞,他们每头奶牛的跳舞时间不同,如果有一只奶牛跳完了第k+1头奶牛就会立刻上场跳舞,当所有奶牛跳完舞以后我们认为这次表演结束.现在给出奶牛个数,最多用时,每头奶牛的跳舞时间.求舞台最小为多大. 思路:本来写了个程序以为这道题很简单,刚开始排一下序然后就行了,结果交了以后发现只过了五组,然后才发现这道题不能改变顺序(所以说为什么我改变顺序了还是能过五组,usaco的数据也好水......),所以说我想到了堆,然后就用堆写了一下