[Python] 프로그래머스 Lv.0 스터디 10문제

Stella·2023년 9월 4일

1. 분수의 덧셈

첫 번째 분수의 분자와 분모를 뜻하는 numer1, denom1, 두 번째 분수의 분자와 분모를 뜻하는 numer2, denom2가 매개변수로 주어집니다. 두 분수를 더한 값을 기약 분수로 나타냈을 때 분자와 분모를 순서대로 담은 배열을 return 하도록 solution 함수를 완성해보세요.

  • math 라이브러리를 이용해서 푸는방법
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]

2. 배열 자르기

def solution(numbers, num1, num2):
    return numbers[num1:num2+1]
  • slice 자르기 : 배열[start:stop] 이렇게 간단하게 사용하면 된다.

3. 중복된 숫자 개수

def solution(array, n):
    answer = array.count(n)
    return answer

count()함수를 사용해서 쉽게 구할 수 있다. 특정 요소의 개수를 구하는 함수이다.

4. 특정 문자 제거하기

  • 문제
    문자열 my_string과 문자 letter이 매개변수로 주어집니다. my_string에서 letter를 제거한 문자열을 return하도록 solution 함수를 완성해주세요.
def solution(my_string, letter):
    return my_string.replace(letter, '')

replace메소드를 사용하여
교체하고 싶은 문자열을 새로 사용하고 싶은 문자열로 변경한다.

5. 순서쌍의 개수

  • 문제
    순서쌍이란 두 개의 숫자를 순서를 정하여 짝지어 나타낸 쌍으로 (a, b)로 표기합니다. 자연수 n이 매개변수로 주어질 때 두 숫자의 곱이 n인 자연수 순서쌍의 개수를 return하도록 solution 함수를 완성해주세요.

def solution(n):
    answer = []
    for i in range(1, n+1):
        if n % i == 0:
            answer.extend([i, n//i])
    return len(answer)
  • extend, append함수의 차이
    extend는 가장 바깥쪽에 글자 하나하나씩 분리해서 리스트 안에 넣는다.
    append는 매개변수 그 자체를 원소로 넣는다.

6. 피자 나눠 먹기

  • 문제
    머쓱이네 피자가게는 피자를 일곱 조각으로 잘라 줍니다. 피자를 나눠먹을 사람의 수 n이 주어질 때, 모든 사람이 피자를 한 조각 이상 먹기 위해 필요한 피자의 수를 return 하는 solution 함수를 완성해보세요.
def solution(n):
    if n % 7 == 0:
        answer = n // 7
    else:
        answer = n // 7 + 1
    return answer

8. 피자 나눠 먹기(3)

  • 문제
    머쓱이네 피자가게는 피자를 두 조각에서 열 조각까지 원하는 조각 수로 잘라줍니다. 피자 조각 수 slice와 피자를 먹는 사람의 수 n이 매개변수로 주어질 때, n명의 사람이 최소 한 조각 이상 피자를 먹으려면 최소 몇 판의 피자를 시켜야 하는지를 return 하도록 solution 함수를 완성해보세요.

  • 풀이

우선 파이썬 math라이브러리를 사용하여

소수점 올림 ceil 함수
소수점 내림 floor 함수

import math 
def solution(slice, n):
    return math.ceil(n/slice)
    

먹는 사람의 수를 피자 조각 수로 나눈 값을 올림 하면 된다.

9. 최댓값 만들기(1)

  • 문제
    정수 배열 numbers가 매개변수로 주어집니다. numbers의 원소 중 두 개를 곱해 만들 수 있는 최댓값을 return하도록 solution 함수를 완성해주세요.

  • 풀기

def solution(numbers):
    numbers.sort(reverse=True)
    return int(numbers[0] * numbers[1])

배열을 sort를 통해 정렬을 한뒤 reverse를 해주면
가장 큰 값과 두번째로 큰 값이 자동으로 온다
첫번째 값과 두번째 값을 곱해준 뒤
return을 해주면 원소 중 두 개를 곱해 만들 수 있는 최댓값이 나온다.

10. 배열의 유사도

  • 문제
    두 배열이 얼마나 유사한지 확인해보려고 합니다. 문자열 배열 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을 리턴한다.

profile
공부 기록

0개의 댓글