Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Git
- Eclipse
- 에러
- 오라클
- Security
- 스프링
- jquery
- GitHub
- error
- 프로그래머스
- 시큐리티
- 넥사크로
- JavaScript
- Vue
- mybatis
- JPA
- Spring
- 코틀린
- Java
- db
- 쿼리
- oracle
- aws
- 방법
- 함수
- 알고리즘
- kotlin
- 자바
- IntelliJ
- 생성
Archives
- Today
- Total
송민준의 개발노트
프로그래머스 - 스킬트리 본문
programmers.co.kr/learn/courses/30/lessons/49993
주어진 스킬들이 선행스킬을 만족하는지 체크하는 문제.
주어진 스킬들을 하나씩 체크해서 선행스킬을 만족하는지 확인해줌.
선행스킬이 기준스킬보다 뒤에 있거나(인덱스가) 없으면 그건 불합격스킬트리임.
package programmers.level2;
public class SkillTree {
public static int solution(String skill, String[] skill_trees) {
int answer = 0;
for(String tree : skill_trees) {
// char 쪼갬
char[] treeCharArray = tree.toCharArray();
// break 및 카운트 체크용
boolean skillCheck = true;
// 체크대상 스킬트리에서 최초스킬부터 어떤 스킬이 선행되어야 하는지 체크
// 에를 들어 "BACDE" 면 B부터 "CBD"에서 체크하면 C가 선행되어야 함
for(Character treeChar : treeCharArray) {
// 필요한 모든 선행스킬을 탐색
for(int i = skill.indexOf(treeChar)-1; i >= 0; i--) {
char needSkill = skill.charAt(i);
// 스킬트리에서 선행되어야 하는 스킬이 기준스킬보다 뒤에 있거나 없으면 불만족 스킬트리임
if(tree.indexOf(needSkill) > tree.indexOf(treeChar)
|| !tree.contains(String.valueOf(needSkill))) {
skillCheck = false;
break;
}
}
// 성능향상을 위해 불필요한 체크는 안함
if(!skillCheck) {
break;
}
}
if(skillCheck) {
answer++;
}
}
return answer;
}
}
아래는 테스트코드
package programmers.level2;
import org.junit.Test;
import static org.junit.Assert.*;
public class SkillTreeTest {
@Test
public void solution() {
//given
String skill = "CBD";
String[] skill_trees = {"BACDE", "CBADF", "AECB", "BDA"};
//when
int solution = SkillTree.solution(skill, skill_trees);
//then
assertEquals(2, solution);
}
}
'알고리즘 > 프로그래머스' 카테고리의 다른 글
프로그래머스 다리를 지나는 트럭 (0) | 2021.02.03 |
---|---|
프로그래머스 두 개 뽑아서 더하기 (0) | 2021.01.31 |
프로그래머스 - 크레인 인형뽑기 게임(카카오) (0) | 2021.01.27 |
프로그래머스-level2-영어 끝말잇기 (0) | 2019.12.09 |
프로그래머스-level2-라면공장 (0) | 2019.12.05 |