첫 번째 분수의 분자와 분모를 뜻하는 numer1, denom1, 두 번째 분수의 분자와 분모를 뜻하는 numer2, denom2가 매개변수로 주어집니다. 두 분수를 더한 값을 기약 분수로 나타냈을 때 분자와 분모를 순서대로 담은 배열을 return 하도록 solution 함수를 완성해보세요.
import math
def solution(numer1, denom1, numer2, denom2):
a = numer1 * denom2 + numer2 * denom1
b = denom1 * denom2
gcd=math.gcd(a,b)
return [a//gcd, b//gcd]
def solution(numbers, num1, num2):
return numbers[num1:num2+1]
def solution(array, n):
answer = array.count(n)
return answer
count()함수를 사용해서 쉽게 구할 수 있다. 특정 요소의 개수를 구하는 함수이다.
def solution(my_string, letter):
return my_string.replace(letter, '')
replace메소드를 사용하여
교체하고 싶은 문자열을 새로 사용하고 싶은 문자열로 변경한다.
def solution(n):
answer = []
for i in range(1, n+1):
if n % i == 0:
answer.extend([i, n//i])
return len(answer)
def solution(n):
if n % 7 == 0:
answer = n // 7
else:
answer = n // 7 + 1
return answer
문제
머쓱이네 피자가게는 피자를 두 조각에서 열 조각까지 원하는 조각 수로 잘라줍니다. 피자 조각 수 slice와 피자를 먹는 사람의 수 n이 매개변수로 주어질 때, n명의 사람이 최소 한 조각 이상 피자를 먹으려면 최소 몇 판의 피자를 시켜야 하는지를 return 하도록 solution 함수를 완성해보세요.
풀이
우선 파이썬 math라이브러리를 사용하여
소수점 올림 ceil 함수
소수점 내림 floor 함수
import math
def solution(slice, n):
return math.ceil(n/slice)
먹는 사람의 수를 피자 조각 수로 나눈 값을 올림 하면 된다.
문제
정수 배열 numbers가 매개변수로 주어집니다. numbers의 원소 중 두 개를 곱해 만들 수 있는 최댓값을 return하도록 solution 함수를 완성해주세요.
풀기
def solution(numbers):
numbers.sort(reverse=True)
return int(numbers[0] * numbers[1])
배열을 sort를 통해 정렬을 한뒤 reverse를 해주면
가장 큰 값과 두번째로 큰 값이 자동으로 온다
첫번째 값과 두번째 값을 곱해준 뒤
return을 해주면 원소 중 두 개를 곱해 만들 수 있는 최댓값이 나온다.
문제
두 배열이 얼마나 유사한지 확인해보려고 합니다. 문자열 배열 s1과 s2가 주어질 때 같은 원소의 개수를 return하도록 solution 함수를 완성해주세요.
풀기
def solution(s1, s2):
answer = 0
for i in s1:
if i in s2:
answer += 1
return answer
for문을 돌려서 s1을 확인한 후
i에 s2값이 있으면 +1을 더해주고
없으면 그냥 0을 리턴한다.