알고리즘/문제

[문자열] 프로그래머스 방금그곡

_Min 2021. 5. 4. 15:35

문제링크 programmers.co.kr/learn/courses/30/lessons/17683

 

 

 

[답코드]

def change(note):
    note=note.replace('C#','c')
    note=note.replace('D#','d')
    note=note.replace('F#','f')
    note=note.replace('G#','g')
    note=note.replace('A#','a')
    return note

def solution(m, musicinfos):
    arr=[] #[제목, 음표]
    m=change(m)

    for mm in musicinfos:
        start, end, title, sound=mm.split(',')
        sound=change(sound)
        
        start_hour, start_min, end_hour, end_min=map(int, start.split(':') + end.split(':'))
        length=(end_hour-start_hour)*60+(end_min-start_min)

        #길이 맞추기
        sound = sound*(length//len(sound))+sound[:length%len(sound)]
        
        arr.append([title, sound])
    
    arr.sort(key=lambda x:len(x[1]), reverse=True)
    
    for i in arr:
        if m in i[1]:
            return i[0]
        
    return "(None)"

 

 

 

[소감]

1차 시도 : C# 같이 # 붙은 친구들은 한 문자로 인식시키기 위해 다른 문자로 바꿔줘야 함 ex)C#->c(소문자)
2차 시도 : return "(None)" 주의
3차 시도 : 분만 고려하지 말고 시간도 고려해줘야 함
4차 시도 : arr 정렬할 때 그냥 정렬하면 오름차순으로 길이가 짧은 게 먼저 나옴, reverse=True 붙여주기

 

 

sort() 하면 오름차순으로 나온다는 것을 꼭 기억해야겠다. 그냥 sort()만 쓰고 어련히 나오겠거니~ 하고 있다가 틀렸다 ㅎ 이래서 테스트가 중요한가보다.

 

 

나는 잘 풀고 있다가도 항상 이게 최고가 아닐 것 같다는 생각이 들어 답을 참고하려고 하는데,

여태까지 그렇게 한 것들이 모두 다 나와 비슷한 방향으로 풀고 있었다. 그냥 이렇게 하는게 맞는지에 대한 확신이 필요했던 것 같다.

 

 

항상 최고는 아니여도 최선을 다해 후회를 두지 않는다는 마인드로 문제를 풀어야겠다.

728x90