반응형
문제
어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요.
제한사항
- absolutes의 길이는 1 이상 1,000 이하입니다.
- absolutes의 모든 수는 각각 1 이상 1,000 이하입니다.
- signs의 길이는 absolutes의 길이와 같습니다.
signs[i]
가 참이면absolutes[i]
의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다.
입출력 예제
입출력 예제 1.
- signs가
[true,false,true]
이므로, 실제 수들의 값은 각각 4, -7, 12입니다. - 따라서 세 수의 합인 9를 return 해야 합니다.
입출력 예제 2.
- signs가
[false,false,true]
이므로, 실제 수들의 값은 각각 -1, -2, 3입니다. - 따라서 세 수의 합인 0을 return 해야 합니다.
내 풀이
def solution(absolutes, signs):
answer = 0
absolutes = list(map(str,absolutes))
signs = list(map(lambda x: '+' if x else '-', signs))
lists = [*sum(zip(signs,absolutes),())]
answer = eval(''.join(lists))
return answer
- 정수들의 절댓값을 담은 정수 배열 absolutes을 문자열 배열로 바꾸어 준다.
- 그리고 정수들의 부호가 담긴 signs 배열을 +, -로 이루어진 문자열 배열로 바꾸어 준다.
- 두 개의 리스트를 하나로 합쳐준다. 리스트의 원소 str.join() 메소드를 사용하여 리스트를 문자열로 변환한다. eval 함수를 이용해 문자열 식 값을 반환해 answer을 리턴한다.
다른 사람의 풀이
def solution(absolutes, signs):
answer=0
for absolute,sign in zip(absolutes,signs):
if sign:
answer+=absolute
else:
answer-=absolute
return answer
느낀 점
- +,- 부호에 꽂혀 문자열로 처리해야하는 것에 집착한게 잘못이었다. 어렵지 않은 문제였는데 반성해야겠다.
반응형
'Algorithm' 카테고리의 다른 글
[Algorithm/Python] 프로그래머스 위클리 챌린지 1주차 / 부족한 금액 계산하기 (0) | 2021.08.18 |
---|