728x90
https://programmers.co.kr/learn/courses/30/lessons/49993
(풀이)
1. Skill의 우선순위를 정한다.
2. Skill_trees 각 String원소들이 우선순위에 맞는지 확인한다.
#include<iostream>
#include <string>
#include <vector>
#include <map>
using namespace std;
map<char, int> _map;
void check_priority(string skill);
bool IsGetSkill(string spell);
int solution(string skill, vector<string> skill_trees) {
int answer = 0;
check_priority(skill);
for (int i = 0; i < skill_trees.size(); ++i)
{
if (IsGetSkill(skill_trees[i]))
answer += 1;
}
return answer;
}
bool IsGetSkill(string spell)
{
int priority = 1;
for (int i = 0; i < spell.size(); ++i)
{
if (_map.find(spell[i]) != _map.end())
{
if (_map[spell[i]] > priority)
return false;
priority += 1;
}
}
return true;
}
void check_priority(string skill)
{
int value = 1;
for (int i = 0; i < skill.size(); ++i)
{
_map[skill[i]] = value;
value += 1;
}
}
300x250
'Algorithm > Programmers' 카테고리의 다른 글
[Summer/winter Coding ~ (2018)] 배달 (0) | 2020.08.07 |
---|---|
[Level1]소수의 합(에라토스테네스의 체) [연습문제] C/C++ (0) | 2018.10.02 |
[Level1] 두 정수 사이의 합 [연습문제] C/C++ (0) | 2018.10.01 |
[Level1] 문자열 내림차순으로 배치하기 [연습문제] C/C++ (0) | 2018.09.20 |
[Level1] 문자열 내 마음대로 정렬하기[연습문제] C/C++ (0) | 2018.09.20 |
댓글