Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- pip
- Visual Studio
- YOLO
- OpenCV
- LIST
- Selenium
- 프로그래머스
- SSH
- paramiko
- 기타 연주
- 오류
- pandas
- 컨테이너
- 핑거스타일
- C++
- JSON
- Python
- 채보
- mysql
- VS Code
- Docker
- Linux
- pytorch
- label
- C
- C#
- ubuntu
- windows forms
- error
- Numpy
Archives
- Today
- Total
기계는 거짓말하지 않는다
[Programmers] 단어 변환 본문
프로그래머스 - 단어 변환 문제입니다.
BFS를 사용하여 시작 단어부터 문자가 단 1개 차이나는 단어를 depth를 늘려 추가해야겠다는 생각을 했습니다.
#include <string>
#include <vector>
#include <queue>
using namespace std;
class WordDepth {
public:
string word;
int depth;
WordDepth() {}
WordDepth(string word, int depth) {
this->word = word;
this->depth = depth;
}
};
int solution(string begin, string target, vector<string> words) {
int i, j, differCnt = 0;
bool check = false;
vector<bool> wordCheckList(words.size(), false); // 검사 했는지
WordDepth preStr; // 현재 비교중인 단어
for(i = 0; i < words.size(); i++) { // target 단어 존재 여부
if(target == words[i]) {
check = true;
break;
}
}
if(check == false) return 0; // target 단어가 없을 경우 리턴
queue<WordDepth> q;
q.push(WordDepth(begin, 0)); // 시작 단어 큐에 추가
while(!q.empty()) {
preStr = q.front(); // 현재 비교 단어 큐에서 가져옴
q.pop();
for(i = 0; i < words.size(); i++) {
if(wordCheckList[i] == true) continue; // 순환 방지
for(j = 0; j < preStr.word.length(); j++) {
if(preStr.word[j] != words[i][j]) differCnt++;
if(differCnt > 1) break;
}
if(differCnt == 1) {
wordCheckList[i] = true;
q.push(WordDepth(words[i], preStr.depth + 1)); // 문자가 1개만 다를 경우 현재 비교 단어의 depth + 1 만큼 늘린 후 큐에 추가
}
if(differCnt == 1 && words[i] == target) return q.back().depth; // 문자가 1개만 다르고 현재 문자가 target 과 같을 경우 정답
differCnt = 0;
}
}
return 0; // target 단어가 있으나 변환 불가
}
단어와 depth를 저장할 수 있는 클래스 선언 후 시작 단어부터 문자가 1개만 다를 경우 depth를 현재 비교 중인 단어 depth + 1로 설정하고 큐에 저장합니다. 큐가 빌 때까지 수행하며, 큐가 비게 되면 변환할 수 없는 경우입니다.
'Programming Test' 카테고리의 다른 글
[Programmers] 이진 변환 반복하기 (0) | 2021.04.30 |
---|---|
[Programmers] 캐시 (0) | 2021.04.30 |
[Programmers] 124 나라의 숫자 (0) | 2021.04.29 |
[Programmers] 튜플 (0) | 2021.04.27 |
[Programmers] 야근 지수 (0) | 2021.04.26 |
Comments