문제 설명
어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요.
제한사항
absolutes의 길이는 1 이상 1,000 이하입니다.
absolutes의 모든 수는 각각 1 이상 1,000 이하입니다.
signs의 길이는 absolutes의 길이와 같습니다.
signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다.
입출력 예
absolutes signs result
[4,7,12] [true,false,true] 9
[1,2,3] [false,false,true] 0
리스트 컴프리헨션을 이용해 작성한 코드
def solution(absolutes, signs):
return sum([absolute * 1 if sign == True else absolute * -1 for absolute,sign in zip(absolutes,signs)])
풀어 작성한 코드
def solution(absolutes, signs):
answer = []
for absolute,sign in zip(absolutes,signs):
if sign == True:
answer.append(absolute*1)
else:
answer.append(absolute*-1)
return sum(answer)
zip함수를 이용해 signs,absolutes 배열을 순회하고
sign이 True 일때 1을 곱하여 양수로 만들고
False일때 -1을 곱해 음수로 만들어서 sum 함수로 합한다.