알고리즘/SW Expert Academy
[SWEA] 7396 종구의 딸 이름 짓기
세진짱
2020. 3. 6. 18:08
메모리와 시간 때문에 많이 틀린 문제다
풀긴했지만 고칠 부분이 많은 코드같다..!
우선 문제를 보면 결국 딸 이름은 n+m-1의 길이를 가질것이다
그럼 시작점부터 해서 가중치가 제일 작은것만 골라서 끝점까지 가면 된다!
다익스트라! 사용하자
각 자리의 알파벳을 가중치라 생각하고 이름을 찾아가다가
n+m-1 길이의 이름을 찾으면 break를하자!
여기서 break안하면 pq에 너무 많이들어가서 메모리가 터진다
소스코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
#include <bits/stdc++.h>
using namespace std;
#define ll long long
char arr[2001][2001];
bool d[2000][2000];
int t,n,m;
int dx[2] = {1,0};
int dy[2] = {0,1};
bool inner(int x,int y){
return (0<=x && x<n && 0<=y && y<m);
}
struct node{
string s;
int _x,_y;
node(string s,int x,int y):s(s),_x(x),_y(y){}
};
bool operator<(node a,node b){
return a.s>b.s;
}
int main(){
scanf(" %d",&t);
for(int tc=1;tc<=t;tc++){
scanf(" %d %d",&n,&m);
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
scanf(" %1c",&arr[i][j]);
d[i][j]=false;
}
}
string ans="";
priority_queue<node>pq;
string start=""; start+=arr[0][0];
string s = p.s;
int x = p._x,y=p._y;
if(d[x][y]) continue;
d[x][y]=true;
if(s.size()==n+m-1) {
ans=s; break;
}
for(int i=0;i<2;i++){
int nx = x+dx[i];
int ny = y+dy[i];
if(inner(nx,ny) && !d[nx][ny])
pq.push(node(s+arr[nx][ny],nx,ny));
}
}
cout<<"#"<<tc<<" "<<ans<<"\n";
}
}
|