TIL#18 ALGORITHM (음양 더하기)

tgrf07·2021년 8월 10일
0
post-thumbnail

문제 설명
어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 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 함수로 합한다.

0개의 댓글