Lv1. 음양더하기

zz·2022년 5월 6일
0

프로그래머스

목록 보기
3/36
post-custom-banner

[월간코드 챌린지 시즌 2 음양더하기]


문제 설명
어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 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)):
        print("absolutes[i]: ",absolutes[i], ", signs[i]: ", signs[i] )
        if signs[i] :
            answer += absolutes[i]
        else : 
            answer -= absolutes[i]
    return answer

간단하게.. 누구나 생각할 수 있는 방식으로 구현했는데, 약간 당황했던건 처음에 if 문을

if (signs[i] == "false"): 

로 뒀었는데, 이 구문이 작동하지 않았다. 프린트해가면서 디버깅을 해봤을때 이 부분에서 문제가 생기는 걸 알아서 지금의 방식으로 고쳤다. python 을 오랜만에 해서 그런지 False 랑 false 가 다르다고 생각했던 것 같다.. 왜 안됐는지는 더 찾아볼 예정임


다른사람 풀이

def solution(absolutes, signs):
    return sum(absolutes if sign else -absolutes for absolutes, sign in zip(absolutes, signs))

이렇게 구현하고 싶었는데, 하는 방식을 몰라서 위의 방식처럼 했던거였는데 딱 다른사람의 풀이 보러가자마자 제일 위에 보여지길래 제법 신났다! 단 한줄로 끝낼 수 있다는 것이 꽤나 놀라웠다.. 한 두세줄 정도는 필요할 것으로 예상했어서,,
공부가.. 역시.. 더 필요하다

profile
응애 나 애기개발자
post-custom-banner

0개의 댓글