hdu 2416 (검색)
사고: 처음에 직접 검색 하려 고 했 는데 잠깐 쓰 면 안 된다 고 생각 했 어 요. 만약 에 몇 가지 경로 에 도착 하 는 시간 이 같 으 면 우 리 는 폭약 을 가장 많이 휴대 해 야 해 요. 그러면 뒤의 시간 이 가장 적 게 보장 할 수 있어 요.그래서 그림 을 3 차원 지도 로 늘 려 점 마다 지 니 고 있 는 폭약 의 최 단 시간 을 기록 했다.
#include<iostream>
#include<queue>
using namespace std;
const int N=110;
const int inf=0x3fffffff;
int dir[4][2]={0,1,0,-1,1,0,-1,0},n,m,t[N][N][27];
bool vis[N][N][27];
char map[N][N];
struct node
{
int x,y,k;
}cur,next;
bool judge(int x,int y)
{
if(x<0||x>=n||y<0||y>=m||map[x][y]=='*')return false;
return true;
}
void bfs()
{
int i,j,x,y,ii,k,sx,sy,ans=inf;
queue<node>Q;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
for(ii=0;ii<27;ii++)
t[i][j][ii]=inf,vis[i][j][ii]=false;
if(map[i][j]=='$') sx=i,sy=j;
else if(map[i][j]=='#'||map[i][j]>='A'&&map[i][j]<='Z')
{
cur.x=i;cur.y=j;
if(map[i][j]=='#')cur.k=0;
else cur.k=map[i][j]-'A'+1;
Q.push(cur);
map[i][j]='*';t[i][j][cur.k]=0;vis[i][j][cur.k]=true;
}
}
}
while(!Q.empty())
{
cur=Q.front();Q.pop();
vis[cur.x][cur.y][cur.k]=false;
for(i=0;i<4;i++)
{
next.x=x=cur.x+dir[i][0];
next.y=y=cur.y+dir[i][1];
next.k=k=cur.k;
if(!judge(x,y))continue;
if((map[x][y]=='.'||map[x][y]=='$')&&t[x][y][k]>t[cur.x][cur.y][k])//
{
t[x][y][k]=t[cur.x][cur.y][k];
if(!vis[x][y][k]){Q.push(next);vis[x][y][k]=true;}
}
else if(map[x][y]>='1'&&map[x][y]<='9')
{
int temp=map[x][y]-'0';
if(t[x][y][k]>t[cur.x][cur.y][k]+temp)//
{
t[x][y][k]=t[cur.x][cur.y][k]+temp;
if(!vis[x][y][k]){Q.push(next);vis[x][y][k]=true;}
}
if(k>0&&t[x][y][k-1]>t[cur.x][cur.y][k])//
{
next.k--;
t[x][y][k-1]=t[cur.x][cur.y][k];
if(!vis[x][y][k-1]){Q.push(next);vis[x][y][k-1]=true;}
}
}
}
}
for(i=0;i<27;i++)
if(ans>t[sx][sy][i]){ans=t[sx][sy][i];}
if(ans<inf)printf("%d
",ans);
else printf("IMPOSSIBLE
");
}
int main()
{
n=0;
while(gets(map[n]),map[n][0]!='-')
{
if(map[n][0]=='\0')
{
m=strlen(map[0]);
bfs();n=-1;
}
n++;
}
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Linux Shell 프로 그래 밍 - 텍스트 처리 grep, sed사용자 가 지정 한 '모드' 에 따라 대상 텍스트 를 일치 하 게 검사 하고 일치 하 는 줄 을 인쇄 합 니 다. ##포함 되 지 않 음, 역방향 일치 \ ##키워드 앞 뒤 가 맞지 않 고 키워드 만 일치 합 니 다...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.