GitHubSeob
C++ / 프로그래머스 / 모음사전 본문
문제 |
https://school.programmers.co.kr/learn/courses/30/lessons/84512
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제풀이 |
완전탐색으로 A부터 EEEEE까지 모든 경우의 수를 set에 저장한 뒤 A부터 탐색하여 풀었다.
미리 char형 배열을 선언하여 'A', 'E', 'I', 'O', 'U'를 저장한다.
DFS를 통해 완전탐색을 한다.
6자리 이상은 구할 필요가 없으므로 cnt > 4이면 return 한다.
(DFS를 실행하기 전에 미리 다음자리의 단어를 구하므로)
그 외의 경우는 현재 고른 알파벳의 개수+1, 현재 만든 단어 + 고른 알파벳을 DFS 인자로 넘긴다.
단어를 저장하는 set에도 저장한다.
코드 |
#include <string>
#include <vector>
#include <set>
using namespace std;
set<string>dict;
char alp[5] = { 'A','E','I','O','U' };
void DFS(int cnt, string word) {
if (cnt > 4) return;
for (int idx = 0; idx < 5; ++idx) {
DFS(cnt + 1, word + alp[idx]);
dict.insert(word + alp[idx]);
}
}
int solution(string word) {
int answer(0);
DFS(0, "");
for (auto iter = dict.begin(); iter != dict.end(); ++iter) {
++answer;
if (*iter == word) return answer;
}
}
'Programmers > Level 2' 카테고리의 다른 글
C++ / 프로그래머스 / [3차] 파일명 정렬 (0) | 2023.08.25 |
---|---|
C++ / 프로그래머스 / 뒤에 있는 큰 수 찾기 (0) | 2023.08.25 |
C++ / 프로그래머스 / 방문 길이 (0) | 2023.08.22 |
C++ / 프로그래머스 / 스킬트리 (0) | 2023.08.22 |
C++ / 프로그래머스 / 게임 맵 최단거리 (0) | 2023.08.22 |