Um dos esportes favoritos na Robolândia é o Rali dos Robôs. Este rali é praticado em uma arena retangular gigante de N linhas por M colunas de células quadradas. Algumas das células estão vazias, algumas contêm figurinhas da Copa (muito apreciadas pelas inteligências artificiais da Robolândia) e algumas são ocupadas por pilastras que sustentam o teto da arena. Em seu percurso os robôs podem ocupar qualquer célula da arena, exceto as que contém pilastras, que bloqueiam o seu movimento. O percurso do robô na arena durante o rali é determinado por uma sequência de instruções. Cada instrução é representada por um dos seguintes caracteres: ‘D’, ‘E’ e ‘F’, significando, respectivamente, “gire 90 graus para a direita”, “gire 90 graus para a esquerda” e “ande uma célula para a frente”. O robô começa o rali em uma posição inicial na arena e segue fielmente a sequência de instruções dada (afinal, eles são robôs!). Sempre que o robô ocupa uma célula que contém uma figurinha da Copa ele a coleta. As figurinhas da Copa não são repostas, ou seja, cada figurinha pode ser coletada uma única vez. Quando um robô tenta andar para uma célula onde existe uma pilastra ele patina, permanecendo na célula onde estava, com a mesma orientação. O mesmo também acontece quando um robô tenta sair da arena.
Dados o mapa da arena, descrevendo a posição de pilastras e figurinhas, e a sequência de instruções de um robô, você deve escrever um programa para determinar o número de figurinhas coletadas pelo robô.
Entrada
A entrada contém vários casos de teste. A primeira linha de um caso de teste contém três números inteiros N, M e S (1 ≤ N, M ≤ 100, 1 ≤ S ≤ 5 × 104 ), separados por espaços em branco, indicando respectivamente o número de linhas e o número de colunas da arena e o número de instruções para o robô. Cada uma das N linhas seguintes da entrada descreve uma linha de células da arena e contém uma cadeia com M caracteres. A primeira linha que aparece na descrição da arena é a que está mais ao Norte; a primeira coluna que aparece na descrição de uma linha de células da arena é a que está mais a Oeste.
Cada célula da arena pode conter um dos seguintes caracteres:
- ‘.’ — célula normal;
- ‘*’ — célula que contém uma figurinha da Copa;
- ‘#’ — célula que contém uma pilastra;
- ‘N’, ‘S’, ‘L’, ‘O’ — célula onde o robô inicia o percurso (única na arena). A letra representa a orientação inicial do robô (Norte, Sul, Leste e Oeste, respectivamente).
A ultima linha da entrada contém uma sequência de S caracteres dentre ‘D’, ‘E’ e ‘F’, representando as instruções do robô.
O último caso de teste é seguido por uma linha que contém apenas três números zero separados por um espaço em branco.
Saída
Para cada rali descrito na entrada seu programa deve imprimir uma única linha contendo um único inteiro, indicando o número de figurinhas que o robô colecionou durante o rali.
Entrada | Saída |
3 3 2 *** *N* *** DE 4 4 5 …# *#O. *.*. *.#. FFEFF 10 10 20 ….*….. …….*.. …..*…. ..*.#….. …#N.*..* …*…… ………. ………. ………. ………. FDFFFFFFEEFFFFFFEFDF 0 0 0 | 0 1 3 |
Dicas
(1) Presente atenção nas orientações para o robô: se a orientação atual do robô é N (norte) e a instrução dada é D (girar 90º para a direita), então a nova orientação do robô é L (leste); (2) Cuidado em relação à uma pilastra: o robô e sua localização na matriz não são alteradas; (3) Observe os limites de linhas e colunas da matriz.
Esse código não é meu e retirei ele de: http://nerdcabecao.blogspot.com.br/2013/02/resolucao-robo-colecionador-2010.html
#include<stdio.h>
struct pos {
int x;
int y;
int prox_x;
int prox_y;
}pos;
int main (void) {
int L, C, S;
while (scanf("%d %d %d", &L, &C, &S)&&L!=0) {
int i, j, fig=0;
char tab[L][C], cmd[S+1];
getchar();
for(i=0; i<L; i++) {
for(j=0; j<C; j++) {
tab[i][j]=getchar();
if(tab[i][j]!='.'&&tab[i][j]!='*'&&tab[i][j]!='#') {
pos.x=i;
pos.y=j;
switch (tab[i][j]) {
case 'N':
pos.prox_x=i-1;
pos.prox_y=j;
break;
case 'S':
pos.prox_x=i+1;
pos.prox_y=j;
break;
case 'L':
pos.prox_x=i;
pos.prox_y=j+1;
break;
case 'O':
pos.prox_x=i;
pos.prox_y=j-1;
break;
}
}
}
getchar();
}
scanf("%s", cmd);
for (i=0; i<S; i++) {
switch (cmd[i]) {
case 'D':
if (pos.prox_y==pos.y) {
if (pos.prox_x>pos.x) {
pos.prox_x=pos.x;
pos.prox_y=pos.y-1;
}
else {
pos.prox_x=pos.x;
pos.prox_y=pos.y+1;
}
}
else {
if (pos.prox_y>pos.y) {
pos.prox_y=pos.y;
pos.prox_x=pos.x+1;
}
else {
pos.prox_y=pos.y;
pos.prox_x=pos.x-1;
}
}
break;
case 'E':
if (pos.prox_x==pos.x) {
if (pos.prox_y>pos.y) {
pos.prox_y=pos.y;
pos.prox_x=pos.x-1;
}
else {
pos.prox_y=pos.y;
pos.prox_x=pos.x+1;
}
}
else {
if (pos.prox_x>pos.x) {
pos.prox_x=pos.x;
pos.prox_y=pos.y+1;
}
else {
pos.prox_x=pos.x;
pos.prox_y=pos.y-1;
}
}
break;
case 'F':
if (tab[pos.prox_x][pos.prox_y]!='#'&&(pos.prox_x<L&&pos.prox_x>-1)&&(pos.prox_y<C&&pos.prox_y>-1)) {
if (tab[pos.prox_x][pos.prox_y]=='*') {
tab[pos.prox_x][pos.prox_y]='.';
fig++;
}
if (pos.prox_y==pos.y) {
if (pos.prox_x>pos.x) {
pos.x=pos.prox_x;
pos.prox_x++;
}
else {
pos.x=pos.prox_x;
pos.prox_x--;
}
}
else {
if (pos.prox_y>pos.y) {
pos.y=pos.prox_y;
pos.prox_y++;
}
else {
pos.y=pos.prox_y;
pos.prox_y--;
}
}
}
break;
}
}
printf("%d\n", fig);
}
return 0;
}
Experimente o código em: https://ideone.com/LwbdEH