https://programmers.co.kr/learn/courses/30/lessons/72411
코딩테스트 연습 - 메뉴 리뉴얼
레스토랑을 운영하던 스카피는 코로나19로 인한 불경기를 극복하고자 메뉴를 새로 구성하려고 고민하고 있습니다. 기존에는 단품으로만 제공하던 메뉴를 조합해서 코스요리 형태로 재구성해서
programmers.co.kr
#include <string>
#include <vector>
#include <map>
#include <algorithm>
using namespace std;
vector<map<string, int>> ordered_count(20);
string cArr[50] = {};
int r = 2; // nCr
void combination(string order, int depth, int next) { //조합 찾기
if (depth == r) {
string list = cArr[0];
for (int i = 1; i < r; i++) {
list += cArr[i];
}
ordered_count[r][list]++;
return;
}
for (int i = next; i < order.size(); i++) {
cArr[depth] = order[i];
combination(order, depth + 1, i + 1);
}
}
vector<string> solution(vector<string> orders, vector<int> course) {
vector<string> answer;
for (string order : orders) { //주문 속 조합 찾기
sort(order.begin(), order.end());
for (int num : course) {
r = num;
combination(order, 0, 0);
}
}
for (int num : course) { //가장 많이 주문한 조합 찾기
int max_count = 0;
vector<string> candidate;
for (auto tmp : ordered_count[num]) {
if (tmp.second >= 2 && max_count <= tmp.second) {
if (max_count < tmp.second) candidate.clear();
max_count = tmp.second;
candidate.push_back(tmp.first);
}
}
answer.insert(answer.end(),candidate.begin(),candidate.end());
}
sort(answer.begin(), answer.end());
return answer;
}
참고한 블로그 :
https://hongchan.tistory.com/5
[C++] 순열(Permutation) 조합(Combination) 알고리즘
백준에서 완전 탐색 문제를 풀다가 항상 조합과 순열을 만들 때 헷갈려서 아예 시간을 내어 정리하였다. 이 네 가지 알고리즘의 뼈대를 이해하면, 여러 방면에 쓰여서 좋은 거 같다. 이후 나오는
hongchan.tistory.com
'전공공부 > 코딩테스트' 카테고리의 다른 글
(c++) 프로그래머스 실패율 (0) | 2022.03.08 |
---|---|
(c++) 프로그래머스 괄호 변환 (0) | 2022.03.07 |
(c++) 프로그래머스 "행렬 테두리 회전하기" (0) | 2022.03.07 |
(c++) 프로그래머스 신고 결과 받기 (0) | 2022.01.14 |
(c++) 프로그래머스 "짝지어 제거하기" (0) | 2022.01.13 |