본문 바로가기
Algorithm

[Algorithm/Python] 프로그래머스 Level1 / 음양 더하기

by @__100.s 2021. 8. 18.
반응형

문제

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

느낀 점

  • +,- 부호에 꽂혀 문자열로 처리해야하는 것에 집착한게 잘못이었다. 어렵지 않은 문제였는데 반성해야겠다.
반응형