728x90
문제 설명
사진들을 보며 추억에 젖어 있던 루는 사진별로 추억 점수를 매길려고 합니다. 사진 속에 나오는 인물의 그리움 점수를 모두 합산한 값이 해당 사진의 추억 점수가 됩니다. 예를 들어 사진 속 인물의 이름이 ["may", "kein", "kain"]이고 각 인물의 그리움 점수가 [5점, 10점, 1점]일 때 해당 사진의 추억 점수는 16(5 + 10 + 1)점이 됩니다. 다른 사진 속 인물의 이름이 ["kali", "mari", "don", "tony"]이고 ["kali", "mari", "don"]의 그리움 점수가 각각 [11점, 1점, 55점]]이고, "tony"는 그리움 점수가 없을 때, 이 사진의 추억 점수는 3명의 그리움 점수를 합한 67(11 + 1 + 55)점입니다.
그리워하는 사람의 이름을 담은 문자열 배열 name, 각 사람별 그리움 점수를 담은 정수 배열 yearning, 각 사진에 찍힌 인물의 이름을 담은 이차원 문자열 배열 photo가 매개변수로 주어질 때, 사진들의 추억 점수를 photo에 주어진 순서대로 배열에 담아 return하는 solution 함수를 완성해주세요.
나의 풀이
def solution(name, yearning, photo):
n = 0
list = []
for p in photo:
for t in p :
for i,s in enumerate(name) :
if s == t:
n += yearning[i]
else :
list.append(n)
n = 0
return list
다른사람 풀이 + 개선점
def solution(이름, 점수, 사진):
return [sum(점수[이름.index(j)] for j in i if j in 이름) for i in 사진]
index를 사용한 풀이방법
index를 사용하면 String의 find처럼 리스트안의 해당 이름이 있는 인덱스번호가 나오게된다.
인덱스번호가 이름과 점수가 동일하기때문에 그 합계를 sum으로 구하면 값이 나오게된다.
728x90
'프로그래머스' 카테고리의 다른 글
프로그래머스 MySQL Lv.2 자동차 평균 대여 기간 구하기 / Lv.3 대여 기록이 존재하는 자동차 리스트 구하기 (0) | 2023.11.27 |
---|---|
프로그래머스 Python 둘만의 암호 (7) | 2023.11.27 |
프로그래머스 MySQL Lv.3 조건에 맞는 사용자 정보 조회하기/조건에 맞는 사용자와 총 거래금액 조회하기 (2) | 2023.11.24 |
프로그래머스 MySQL Lv.3 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기 (2) | 2023.11.23 |
프로그래머스 MySQL 조건에 부합하는 중고거래 댓글/상태 조회하기 (4) | 2023.11.23 |