반응형
📖 문제
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
💡 풀이 방식
• 문자열 (브루트포스)
1. #이 붙은 부분을 다른 문자로 치환한다.
m = m.replace("C#", "c")
.replace("D#", "d")
.replace("F#", "f")
.replace("G#", "g")
.replace("A#", "a")
.replace("B#", "b");
2. musicinfos 배열을 돌며 악보와 재생시간을 구한다.
1) #이 붙은 부분을 또 1과 같이 다른 문자로 대체한다.
String[] info = music.split(",");
int play = getLastingTime(info[0], info[1]); // 총 재생시간
// #이 붙은 부분 소문자로 대체
info[3] = info[3].replace("C#", "c")
.replace("D#", "d")
.replace("F#", "f")
.replace("G#", "g")
.replace("A#", "a")
.replace("B#", "b");
2) 악보 길이만큼 전체 멜로디를 만든다.
StringBuilder sb = new StringBuilder(); // 전체 멜로디
for(int i = 0 ; i < play ; i++) {
sb.append(info[3].charAt(i % info[3].length()));
}
3) 완성된 악보에 m이 포함되고, 재생시간이 최대 재생시간보다 긴 경우, 최대 재생시간을 더 큰 값으로 갱신하고, 결과값을 저장한다.
if(sb.toString().contains(m)) {
if(maxTime < play) {
maxTime = play; // 최대 재생시간 바꿈
answer = info[2]; // 결과값 저장
}
}
🔺 코드
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
import java.util.*;
class Solution {
public String solution(String m, String[] musicinfos) {
String answer = "(None)";
int maxTime = -1;
// #이 붙은 부분을 소문자로 치환
m = m.replace("C#", "c")
.replace("D#", "d")
.replace("F#", "f")
.replace("G#", "g")
.replace("A#", "a")
.replace("B#", "b");
for(String music : musicinfos) {
String[] info = music.split(",");
int play = getLastingTime(info[0], info[1]); // 총 재생시간
// #이 붙은 부분 소문자로 대체
info[3] = info[3].replace("C#", "c")
.replace("D#", "d")
.replace("F#", "f")
.replace("G#", "g")
.replace("A#", "a")
.replace("B#", "b");
StringBuilder sb = new StringBuilder(); // 전체 멜로디
for(int i = 0 ; i < play ; i++) {
sb.append(info[3].charAt(i % info[3].length()));
}
// 완성된 악보에 m이 포함되고, 가장 긴 멜로디인 경우
if(sb.toString().contains(m)) {
if(maxTime < play) {
maxTime = play; // 최대 재생시간 바꿈
answer = info[2]; // 결과값 저장
}
}
}
return answer;
}
// 총 재생시간 계산 메소드
private static int getLastingTime(String s1, String s2) {
String[] t1 = s1.split(":");
String[] t2 = s2.split(":");
return (Integer.parseInt(t2[0]) *60 + Integer.parseInt(t2[1])) - (Integer.parseInt(t1[0])*60 + Integer.parseInt(t1[1]));
}
}
|
cs |
💦 어려웠던 점
- #을 어떻게 처리하지?의 문제...
- 가장 긴 멜로디인 경우 처리도 빠뜨렸다,,,,하하
이것만 아니었음 빨리 풀었을 듯,,
🧐 새로 알게 된 내용
- 그냥 다른 문자열로 치환하면 되는 문제였다 ㄴㅇㄱ
1회독 | 2회독 | 3회독 | 4회독 | 5회독 |
V |
(참고)
✔ 풀이 참고
[알고리즘] 프로그래머스 [3차] 방금그곡 (2018 KAKAO BLIND RECRUITMENT) -문자열, 구현- 자바
https://programmers.co.kr/learn/courses/30/lessons/17683?language=java 코딩테스트 연습 - [3차] 방금그곡 방금그곡 라디오를 자주 듣는 네오는 라디오에서 방금 나왔던 음악이 무슨 음악인지 궁금해질 때가 많다.
youngest-programming.tistory.com
반응형
'코테 > 프로그래머스' 카테고리의 다른 글
[프로그래머스/Level3] 불량 사용자 (JAVA) (0) | 2024.05.13 |
---|---|
[프로그래머스/Level 3] 아이템 줍기 (JAVA) (0) | 2024.04.23 |
[프로그래머스/Level2] 숫자 블록 (JAVA) (0) | 2024.04.11 |
[프로그래머스/Level2] 후보키 (JAVA) (0) | 2024.04.08 |
[프로그래머스/Level1] 달리기 경주 (JAVA) (0) | 2024.04.06 |