문제 설명
어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요.
제한사항
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))
이렇게 구현하고 싶었는데, 하는 방식을 몰라서 위의 방식처럼 했던거였는데 딱 다른사람의 풀이 보러가자마자 제일 위에 보여지길래 제법 신났다! 단 한줄로 끝낼 수 있다는 것이 꽤나 놀라웠다.. 한 두세줄 정도는 필요할 것으로 예상했어서,,
공부가.. 역시.. 더 필요하다