💻 현생/⛓ 알고리즘
[백준] 9019번 : DSLR
영이오
2021. 5. 10. 17:01
문제
풀이
문제 자체는 그냥 간단한 BFS였는데 그 과정이 너무 더럽다고 해야하나 짜증나게 한다고 해야하나 암튼 그랬다.
D, S까지는 그렇다고 치고 L, R을 구현하는게 문제인데, 제일 먼저 생각난건 string이라 그걸로 했더니 tle가 났다.
그러다가 잘 생각해보니 이거 그냥 수학으로 되는 연산이었다...이것만 빨리 알아챘어도..
소스코드
#include <iostream>
#include <vector>
#include <string>
#include <queue>
#include <utility>
using namespace std;
string bfs(int source, int target) {
vector<bool> visited;
visited.assign(10000, false);
queue<pair<int, string>> q;
visited[source] = true;
q.push(make_pair(source, ""));
while (!q.empty()) { //벡터로 처리하려고 했는데 벡터 하나 썼다고 TLE 발생
int cur = q.front().first;
string str = q.front().second;
q.pop();
if (cur == target) //target 찾음
return str;
int next_num;
next_num = (2 * cur) % 10000; //D
if (!visited[next_num]) {
visited[next_num] = true;
q.push(make_pair(next_num, str + "D"));
}
next_num = (cur - 1 < 0) ? 9999 : cur - 1; //S
if (!visited[next_num]) {
visited[next_num] = true;
q.push(make_pair(next_num, str + "S"));
}
next_num = ((cur % 1000) * 10) + (cur / 1000); //L
if (!visited[next_num]) {
visited[next_num] = true;
q.push(make_pair(next_num, str + "L"));
}
next_num = ((cur % 10) * 1000) + (cur / 10); //R
if (!visited[next_num]) {
visited[next_num] = true;
q.push(make_pair(next_num, str + "R"));
}
}
return "";
}
int main() {
ios::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
int T, A, B;
cin >> T;
for (int i = 0; i < T; i++) {
cin >> A >> B;
cout << bfs(A, B) << '\n';
}
}
전체 소스코드다. next_num을 저런식으로 하고 싶지 않아서
모든 next_num들을 벡터에 넣고 for문을 돌며 하려 했는데 TLE를 뱉어냈다. 세상에 마상에...
문제가 좀 지저분할 뿐이지 어려운 구석은 없어서 설명은 굳이 하지 않겠다.