No Rules Rules

메뉴 리뉴얼 (feat. 프로그래머스, 72411번) 본문

생활/코테

메뉴 리뉴얼 (feat. 프로그래머스, 72411번)

개발하는 완두콩 2022. 7. 25. 14:23
728x90
반응형

메뉴 리뉴얼
https://school.programmers.co.kr/learn/courses/30/lessons/72411

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

반응형

 

// woohyeon.kim
// https://school.programmers.co.kr/learn/courses/30/lessons/72411
#include <string>
#include <vector>
#include <map>
#include <algorithm>
using namespace std;
bool visit[20];
string item, tmp;
map<string,int> ans;
void dfs(int index, int count, string& order){
    if(2<=count&&count<=10){
        tmp=item;
        sort(tmp.begin(), tmp.end());     // 알파벳 순으로 정렬
        ++ans[tmp];
    }
    else if(count>10)       // 10개까지만 보관
        return;
    for(int i=index;i<order.size();++i){
        if(!visit[i]){
            visit[i]=true;
            item.push_back(order[i]);
            dfs(i+1,count+1,order);
            visit[i]=false;
            item.pop_back();
       }
    }
}
vector<string> solution(vector<string> orders, vector<int> course) {
    fill(visit, visit+20, false);
    vector<string> answer;
    for(auto& order : orders){
        dfs(0,0,order);
    }
    for(const auto& c : course){
        int max_count = 0;
        for(auto iter=ans.begin(); iter!=ans.end(); ++iter){
            if(iter->first.size() == c)
                max_count=max(max_count, iter->second);   // course별 최대 문자열 찾기
        }
        if(max_count == 1)
            continue;
        for(auto iter=ans.begin(); iter!=ans.end(); ++iter)
            if(iter->first.size() == c && iter->second == max_count)
                answer.push_back(iter->first);
    }
    sort(answer.begin(), answer.end());
    return answer;
}
//

 

  1. 알파벳 2개~10개에 대한 모든 조합을 구합니다.
  2. 구해진 조합을 알파벳 순으로 정렬하고 그 개수를 보관합니다.
  3. course로 주어진 알파벳 길이중 가장 많은 개수를 가진 알파벳을 출력합니다.
728x90
반응형
Comments