1. 콜라츠 추측
문제설명
1937년 Collatz란 사람에 의해 제기된 이 추측은, 주어진 수가 1이 될 때까지 다음 작업을 반복하면, 모든 수를 1로 만들 수 있다는 추측입니다. 작업은 다음과 같습니다.
- 입력된 수가 짝수라면 2로 나눕니다.
- 입력된 수가 홀수라면 3을 곱하고 1을 더합니다.
- 결과로 나온 수에 같은 작업을 1이 될 때까지 반복합니다.
예를 들어, 주어진 수가 6이라면 6 → 3 → 10 → 5 → 16 → 8 → 4 → 2 → 1 이 되어 총 8번 만에 1이 됩니다. 위 작업을 몇 번이나 반복해야 하는지 반환하는 함수, solution을 완성해 주세요. 단, 주어진 수가 1인 경우에는 0을, 작업을 500번 반복할 때까지 1이 되지 않는다면 –1을 반환해 주세요
내 풀이
def solution(num):
for i in range(500):
if num == 1:
return i
if num % 2 == 0:
num = num / 2
else:
num = num * 3 + 1
return -1
다른 사람 풀이
def solution(num):
answer = 0
if num == 1:
return 0
while num != 1:
if num % 2 == 0:
num = num / 2
answer += 1
elif num % 2 != 1:
num = num * 3 + 1
answer += 1
if answer >= 500:
return -1
2. 음양 더하기
문제 설명
어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요.
제한사항
absolutes의 길이는 1 이상 1,000 이하입니다.
absolutes의 모든 수는 각각 1 이상 1,000 이하입니다.
signs의 길이는 absolutes의 길이와 같습니다.
signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다.
내 풀이
def solution(absolutes, signs):
for i in range(len(absolutes)):
if signs[i] == False:
absolutes[i] = absolutes[i] * (-1)
else:
absolutes[i] = absolutes[i]
return sum(absolutes)
다른 사람 풀이
def solution(absolutes, signs):
answer=0
for absolute,sign in zip(absolutes,signs):
if sign:
answer+=absolute
else:
answer-=absolute
return answer
zip() : 여러 개의 순회 가능한(iterable) 객체를 인자로 받고, 각 객체가 담고 있는 원소를 튜플의 형태로 차례로 접근할 수 있는 반복자(iterator)를 반환
'PYTHON > 프로그래머스 코딩테스트 연습' 카테고리의 다른 글
[프로그래머스] 파이썬 코딩테스트 연습 LV1(없는 숫자 더하기, 핸드폰 번호 가리기) (0) | 2023.12.11 |
---|---|
[프로그래머스] 파이썬 코딩테스트 연습 LV1(서울에서 김서방 찾기, 나누어 떨어지는 숫자 배열) (2) | 2023.12.08 |
[프로그래머스] 파이썬 코딩테스트 연습 LV2(최댓값과 최솟값) (3) | 2023.12.04 |
[프로그래머스] 파이썬 코딩테스트 연습 LV1(문자열을 정수로 바꾸기, 두 정수 사이의 합) (2) | 2023.12.01 |
[프로그래머스] 파이썬 코딩테스트 연습 LV1(정수 내림차순으로 배치하기, 하샤드 수) (0) | 2023.11.29 |