https://school.programmers.co.kr/learn/courses/30/lessons/118666
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
def solution(survey, choices):
score = {1:-3, 2:-2, 3:-1, 4:0, 5:1, 6:2, 7:3}
t = {"R":0, "T":0, "C":0, "F":0, "J":0, "M":0, "A":0, "N":0}
l = []
ans = ""
for i in range(len(choices)):
if score[choices[i]] < 0:
t[survey[i][0]] += abs(score[choices[i]])
elif score[choices[i]] > 0:
t[survey[i][1]] += abs(score[choices[i]])
for k,v in t.items():
l.append((v,k))
for i in range(1,len(l),2):
if l[i][0] == l[i-1][0]:
ans += min(l[i][1], l[i-1][1])
elif l[i][0] > l[i-1][0]:
ans += l[i][1]
else:
ans += l[i-1][1]
return ans
for문을 너무 많이 쓴 것 같다..좋은 풀이법은 아닌 것 같다..
일단 딕셔너리를 이용해서 점수, 유형을 각각 순서대로 담아주었다.
그리고 choices에 해당하는 score의 값을 t에 담아주었다.(음수일경우 -를 없애기 위해 abs이용)
items(),튜플이용해서 배열l에 (값,키)를 담아줌
각 조건에 맞게 출력하게 반복문,조건문 작성
| [파이썬] 프로그래머스 : 로또의 최고 순위와 최저 순위 (Lv.1) (0) | 2023.01.17 |
|---|---|
| [파이썬/python] 프로그래머스 : 문자열 나누기(Lv.1) (0) | 2023.01.16 |
| [파이썬/python] 프로그래머스 : 개인정보 수집 유효기간(Lv.1) (0) | 2023.01.16 |
| [파이썬/python] 프로그래머스 : k번째수(Lv.1)(feat.lambda) (0) | 2022.12.23 |
| [파이썬/python] 프로그래머스 : 크키가 작은 부분 문자열(Lv.1) (0) | 2022.12.23 |