Python/Coding Test 기록

[백준/1620] 나는야 포켓몬 마스터 이다솜 (해시,딕셔너리)

yerinn 2022. 1. 20. 12:29

입력

첫째 줄에는 도감에 수록되어 있는 포켓몬의 개수 N이랑 내가 맞춰야 하는 문제의 개수 M이 주어져. N과 M은 1보다 크거나 같고, 100,000보다 작거나 같은 자연수인데, 자연수가 뭔지는 알지? 모르면 물어봐도 괜찮아. 나는 언제든지 질문에 답해줄 준비가 되어있어.

둘째 줄부터 N개의 줄에 포켓몬의 번호가 1번인 포켓몬부터 N번에 해당하는 포켓몬까지 한 줄에 하나씩 입력으로 들어와. 포켓몬의 이름은 모두 영어로만 이루어져있고, 또, 음... 첫 글자만 대문자이고, 나머지 문자는 소문자로만 이루어져 있어. 아참! 일부 포켓몬은 마지막 문자만 대문자일 수도 있어. 포켓몬 이름의 최대 길이는 20, 최소 길이는 2야. 그 다음 줄부터 총 M개의 줄에 내가 맞춰야하는 문제가 입력으로 들어와. 문제가 알파벳으로만 들어오면 포켓몬 번호를 말해야 하고, 숫자로만 들어오면, 포켓몬 번호에 해당하는 문자를 출력해야해. 입력으로 들어오는 숫자는 반드시 1보다 크거나 같고, N보다 작거나 같고, 입력으로 들어오는 문자는 반드시 도감에 있는 포켓몬의 이름만 주어져. 그럼 화이팅!!!

출력

첫째 줄부터 차례대로 M개의 줄에 각각의 문제에 대한 답을 말해줬으면 좋겠어!!!. 입력으로 숫자가 들어왔다면 그 숫자에 해당하는 포켓몬의 이름을, 문자가 들어왔으면 그 포켓몬의 이름에 해당하는 번호를 출력하면 돼. 그럼 땡큐~

예제 입력 1 

26 5
Bulbasaur
Ivysaur
Venusaur
Charmander
Charmeleon
Charizard
Squirtle
Wartortle
Blastoise
Caterpie
Metapod
Butterfree
Weedle
Kakuna
Beedrill
Pidgey
Pidgeotto
Pidgeot
Rattata
Raticate
Spearow
Fearow
Ekans
Arbok
Pikachu
Raichu
25
Raichu
3
Pidgey
Kakuna

 

예제 출력 1

Pikachu
26
Venusaur
16
14

 

N과 M은 1보다 크거나 같고, 100,000보다 작거나 같은 자연수이다.

이말은? for 문을 돌리면 효율성에서 나락으로 갈 수 있다는 것 ㅎ

난 코린이라 for _ in range 무새 인데.. 

이런나에게 for문을 쓰지 말란것은 넘나 가혹한것 ㅠㅠ

 

할튼!!

반복문을 안돌리고 체킹으로 값을 return 할수 있으려면?

-> dictionary 구조를 사용한다! ☆ (해시)

 

 

답안 작성은

https://jennnn.tistory.com/34님의 게시물을 참고하였습니다!!

 

[백준] 1620. 나는야 포켓몬 마스터 이다솜 / python 파이썬

🚩 자료구조, 문자열, 해시를 이용한 집합과 맵 1. 시간초과 (fail) 문제보자마자 바로 enumerate으로 index랑 value 출력했는데 시간초과가 났다. N, M = map(int, input().split()) lst = [input() for _ in ran..

jennnn.tistory.com

답안

import sys
input = sys.stdin.readline

N, M = map(int, input().split())
dic_n = {}  # {'25': 'Pikachu'}. 숫자접근으로 문자출력용
dic_s = {}  # {'Pikachu': 25}. 문자접근으로 숫자출력용
for i in range(N):
    value = input().strip() #strip으로 문자열 앞뒤 공백제거
    dic_n[str(i+1)] = value # {'1':'포켓몬1', '2':'포켓몬2',...}
    dic_s[value] = i+1  # {'포켓몬1':'1', '포켓몬2':'2',...}

for j in range(M):
    quest = input().strip()
    if quest.isdigit():  # 숫자면 문자출력
        print(dic_n[quest])
    if quest.isalpha():  # 문자면 숫자출력
        print(dic_s[quest])

1. 반복문으로 여러줄(N)을 입력받아야 하기 때문에, input() 대신 sys.stdin.readline 을 이용한다.

단 얘는 개행문자(\n)를 포함하기 때문에 값을 받을 때, input().strip()를 항상 붙여줘야한다. (앞뒤 여백제거)

 

2. 딕셔너리는 '문자'로 받아올 때, '숫자'로 받아올 때 두가지 경우이기 때문에 2개로 만든다.