문제 설명
어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요.
제한사항
- absolutes의 길이는 1 이상 1,000 이하입니다.
- absolutes의 모든 수는 각각 1 이상 1,000 이하입니다.
- signs의 길이는 absolutes의 길이와 같습니다.
- signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다.
입출력 예
풀이
def solution(absolutes, signs):
answer = 0
for i in range(len(absolutes)):
if signs[i] == 1:
answer += absolutes[i]
else:
answer -= absolutes[i]
return answer
다른풀이
def solution(absolutes, signs):
return sum(absolutes if sign else -absolutes for absolutes, sign in zip(absolutes, signs))
zip을 사용하여 한줄로 푸는 풀이이다. zip을 잘 활용해야겠다.
'Algorithm' 카테고리의 다른 글
[프로그래머스 Level1] 약수의 개수와 덧셈 (0) | 2021.08.04 |
---|---|
[프로그래머스 Level1] 두 개 뽑아서 더하기 (0) | 2021.08.02 |
[프로그래머스 Level1] 크레인 인형뽑기 게임 (0) | 2021.08.01 |
[프로그래머스 Level1] 내적 (0) | 2021.08.01 |
[프로그래머스 Level1] 모의고사 (0) | 2021.07.31 |