루트를 이용해 루트가 정수값일 경우 x + 1 의 제곱을 리턴하고 아닐경우 no를 리턴하자 import math def nextSqure(n): if math.sqrt(n) == int(math.sqrt(n)): return int((math.sqrt(n) + 1) ** 2) return 'no' # 아래는 테스트로 출력해 보기 위한 코드입니다. print("결과 : {}".format(nextSqure(121)));
isdigit() 함수를 이용하여 숫자로만 구성되어 있는지 확인한다. def alpha_string46(s): if s.isdigit(): return True elif len(str(s))!=4 and len(str(s)) != 6: return False else: return False # 아래는 테스트로 출력해 보기 위한 코드입니다. print( alpha_string46('a234') ) print( alpha_string46('11828') )
홀수일때는 길이 // 2 에 위치한 문자를 반환하고,짝수일때는 길이 // 2 - 1 ~ 길이 // 2 에 위치한 문자들을 반환하면 된다. def string_middle(str1): if len(str1) % 2 == 1: str2 = len(str1) // 2 return str1[str2] else: str2 = len(str1) // 2 return str1[str2 - 1 : str2 + 1] # 아래는 테스트로 출력해 보기 위한 코드입니다. print(string_middle("power"))
평범하게 재귀함수 사용하면 시간초과가 된다.그래서 리스트에 값을 저장하는 방식으로 풀어보았다. def fibonacci(n): num = [0] * n num[0:1] = [0,1] if n == 0: return 0 if n == 1: return 1 for rpt in range(2, n + 1): num[rpt] = num[rpt - 1] + num[rpt - 2] return num[n] # 아래는 테스트로 출력해 보기 위한 코드입니다. print(fibonacci(8))