내일배움캠프 AI/페어프로그래밍
[페어프로그래밍] 230418 콜라츠 추측 | while if 삼항연산자
생각하는 코댕이
2023. 4. 18. 11:18
728x90
페어프로그래밍 결과 코드
# 페어프로그래밍으로 제작한 코드
def solution(num):
# 주어진 수 num이 1 일 때 와 짝수 일 때, 홀수 일 때로 분리
# num이 1 일 때
if num == 1:
answer = 0
# num이 1이 될 때까지 반복, 반복횟수는 answer
while num > 1:
# num이 짝수 일 때
if num%2 == 0:
num = num/2
# num이 홀수 일 때
else:
num = num*3 + 1
answer += 1
# 반복횟수가(answer)가 500번이 넘었을 경우 반복문 탈출과 -1 반환
if answer > 500:
answer = -1
break
return answer
리팩토링 코드
# 리팩토링 코드
def solution(num):
# 주어진 수 num이 1 일 때 와 짝수 일 때, 홀수 일 때로 분리
answer = 0
# num이 1 일 때
while num > 1:
# 삼항연산자 사용
num = num/2 if num%2 == 0 else num*3 + 1
answer += 1
if answer > 500:
answer = -1
break
else:
answer = answer
return answer
흠터레스링 코드
#1번 흠터레스팅 코드
def collatz(num):
for i in range(500):
num=num/2 if num%2==0 else num*3+1
if num==1:
return i+1
return -1
#2번 흠터레스팅 코드
def collatz(num):
answer = 0
while num!=1:
if num%2==0:
num=num/2
else:
num=3*num+1
answer=answer+1
if answer>=500:
return -1
return answer
시사점 or 새로이 알게된 점
#
728x90