• 분류 전체보기 (512)
    • 개발남노씨(Coding Test) (6)
    • 고농축 백엔드 (17)
    • 재귀함수 DFS 총정리 (1)
    • 프론트엔드 날개달기:Vuejs.React (1)
    • 훈훈한 javascript (5)
    • 렛츠기릿 자바스크립트 (18)
    • 나도코딩 (1)
      • 웹 스크래핑 (1)
    • 프로그래머스(자바스크립트) (41)
      • LV.0(자바스크립트) (41)
    • 프로그래머스(자바) (121)
      • LV.0(자바) (56)
      • LV.1(자바) (41)
      • LV.2(자바) (23)
    • 프로그래머스(파이썬) (127)
      • LV.0(파이썬) (46)
      • LV.1(파이썬) (51)
      • LV.2(파이썬) (30)
    • 임시저장소 (31)
    • 프로젝트 (0)
    • 자바 알고리즘 (13)
      • 알고리즘 직빵 자바 문법 (10)
      • String(문자열) (3)
    • 파이썬 알고리즘 (93)
      • 알고리즘 직빵 파이썬 문법 (20)
      • 알고리즘 백준 (2)
      • 파이썬 알고리즘(사고력기르기) (6)
      • 파이썬 탐색 & 시물레이션 (8)
      • 이분탐색 & 그리디 알고리즘 (10)
      • 스택, 큐, 해쉬, 힙 (10)
      • 완전탐색과 DFS기초 (12)
      • DFS, BFS 활용 (19)
      • 동적계획법 (6)
    • 자바 (27)
      • Java TPC(생각하고, 표현하고, 코딩하고) (17)
      • Java (중요하고, 이해 안 되고, 어려운) (10)
    • 스프링 (5)
      • 스프링 MVC 패턴 2편 (5)
hELLO · Designed By 정상우.
@@#@@

기록용 블로그

프로그래머스(파이썬)/LV.1(파이썬)

키패드 누르기→매개변수로 값주기, 현재값, next값★

2022. 12. 20. 23:05

나의 풀이 

def solution(numbers, hand):
    # 1. 왼손 오른손 위치를 초기화 
    left_key= [1,4,7]
    right_key= [3,6,9]
    hand_position=['*', '#']


    keyPad = {
               1:(0,0), 2:(0,1), 3:(0,2),
               4:(1,0), 5:(1,1), 6:(1,2),
               7:(2,0), 8:(2,1), 9:(2,2),
               '*':(3,0), 0:(3,1), '#':(3,2)
               
    }
   


    # 2. 숫자를 누를 손가락 정하기
    answer=""
    for num in numbers:
        if num in left_key:
            hand_position[0]=num
            answer+="L"
          
        
        elif num in right_key:
            hand_position[1]=num
            answer+="R"
          
        
        else:
            #더 가까운 손으로 누른다.
            #여기서 num은 if문과 elif문을 skip하고 왔으며, next_step이다.
            near_hand = get_near_hand(keyPad, hand_position[0], hand_position[1],num, hand)
            if near_hand == 'L':
                hand_position[0]=num
                answer+='L'

            else:
                hand_position[1]=num
                answer+='R'
    
    return answer
             


def get_near_hand(keyPad, l, r, num, hand):
    #abs(현재위치 - next_step)
    #x좌표 + y좌표
    left_distance = abs(keyPad[l][0]-keyPad[num][0])+abs(keyPad[l][1]-keyPad[num][1])
    

    right_distance= abs(keyPad[r][0]-keyPad[num][0])+abs(keyPad[r][1]-keyPad[num][1])
    
    if right_distance>left_distance:
        return "L"


    elif right_distance<left_distance:
        return "R"

    elif right_distance== left_distance:
        if hand == "right":
            return "R"
        else:
            return "L"

 

 

다른 사람의 풀이 

def solution(numbers, hand):
    answer = ''
    key_dict = {1:(0,0),2:(0,1),3:(0,2),
                4:(1,0),5:(1,1),6:(1,2),
                7:(2,0),8:(2,1),9:(2,2),
                '*':(3,0),0:(3,1),'#':(3,2)}

    left = [1,4,7]
    right = [3,6,9]
    lhand = '*'
    rhand = '#'
    for i in numbers:
        if i in left:
            answer += 'L'
            lhand = i
        elif i in right:
            answer += 'R'
            rhand = i
        else:
            curPos = key_dict[i]
            lPos = key_dict[lhand]
            rPos = key_dict[rhand]
            ldist = abs(curPos[0]-lPos[0]) + abs(curPos[1]-lPos[1])
            rdist = abs(curPos[0]-rPos[0]) + abs(curPos[1]-rPos[1])

            if ldist < rdist:
                answer += 'L'
                lhand = i
            elif ldist > rdist:
                answer += 'R'
                rhand = i
            else:
                if hand == 'left':
                    answer += 'L'
                    lhand = i
                else:
                    answer += 'R'
                    rhand = i

    return answer
저작자표시 비영리 변경금지 (새창열림)

'프로그래머스(파이썬) > LV.1(파이썬)' 카테고리의 다른 글

크레인 인형 뽑기 →"열"접근★★ + 전부 1씩 빼주기(람다식)★★  (0) 2022.12.21
폰켓몬★★ → 해설, 조합X  (0) 2022.12.21
숫자 짝꿍 → 일치 + count() + min(a,b) + len(answer) == a.count('0')★★ + 모든 요소가 0인 경우  (0) 2022.12.20
과일장수 →특정요소 여러 개 제거★★+ 1차원 리스트 슬라이싱(n등분)★★  (0) 2022.12.20
가장 가까운 글자→ 다중 index를 이용★★  (0) 2022.12.20
    '프로그래머스(파이썬)/LV.1(파이썬)' 카테고리의 다른 글
    • 크레인 인형 뽑기 →"열"접근★★ + 전부 1씩 빼주기(람다식)★★
    • 폰켓몬★★ → 해설, 조합X
    • 숫자 짝꿍 → 일치 + count() + min(a,b) + len(answer) == a.count('0')★★ + 모든 요소가 0인 경우
    • 과일장수 →특정요소 여러 개 제거★★+ 1차원 리스트 슬라이싱(n등분)★★
    @@#@@
    @@#@@
    자바, 스프링, 알고리즘, 깃허브, 파이썬

    티스토리툴바