Algorithm/프로그래머스

[프로그래머스] 스킬트리 (Java)

Carroti 2022. 11. 7. 17:07

 

문제

 

프로그래머스

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

programmers.co.kr

 

알고리즘

없음

 

풀이

스킬트리에서 스킬들의 index를 찾고, 그 index들이 오름차순이라면 올바른 스킬트리이다.

String의 indexOf 메소드를 사용할 경우 스킬이 없으면 -1을 반환하는데, 이 때문에 스킬을 찍지 않았는데 오름차순 조건을 만족할 수 있다.

따라서 스킬이 없어서 -1 을 반환하면 -1이 아닌 26보다 큰 값으로 바꿔서 비교해야한다.

 

코드

class Solution {
    public int solution(String skill, String[] skill_trees) {
        int answer = 0;
        
        label1: for(String str: skill_trees) {
            for(int i=0; i<skill.length()-1; i++) {
                int before = str.indexOf(skill.charAt(i)) != -1 ? str.indexOf(skill.charAt(i)) : 100; 
                int after = str.indexOf(skill.charAt(i+1)) != -1 ? str.indexOf(skill.charAt(i+1)) : 100; 
                if(before > after) {
                    continue label1;
                }
            }

            answer++;
        }
        
        return answer;
    }
}