문제 푸는 방법

  1. 문제 푸는 방법을 글로 정리
  2. 정리된 생각을 한 줄씩 코드로 구현
  3. 제한 시간 안에 풀리지 않으면 정답 코드 확인

오답 문제 공부 방법

  1. 못 푼 문제는 정답 코드를 한 줄씩 글로 번역해보기
  2. 번역한 글만보고 다시 코드로 구현하기

파이썬 기초 문법에 대해 잘 모르고
파이썬으로 함수를 어떻게 만드는지 잘 모르시는 분들은
먼저 제 벨로그의 파이썬 왕초보 시리즈함수 만들기 글을 보고 풀어보시는 걸 추천드립니다.😉


1. 나머지 구하기

✅ 문제 설명

문제 설명

정수 num1, num2가 매개변수로 주어질 때, num1를 num2로 나눈 나머지를 return 하도록 solution 함수를 완성해주세요.

제한사항

0 < num1 ≤ 100
0 < num2 ≤ 100

입출력 예시

num1num2result
321
1050

입출력 예시 설명

  • 입출력 예 #1
    num1이 3, num2가 2이므로 3을 2로 나눈 나머지 1을 return 합니다.
  • 입출력 예 #2
    num1이 10, num2가 5이므로 10을 5로 나눈 나머지 0을 return 합니다.

✅ 해설

def solution(num1, num2):
    return num1 % num2

2. 중앙값 구하기

✅ 문제 설명

문제 설명

중앙값은 어떤 주어진 값들을 크기의 순서대로 정렬했을 때 가장 중앙에 위치하는 값을 의미합니다. 예를 들어 1, 2, 7, 10, 11의 중앙값은 7입니다. 정수 배열 array가 매개변수로 주어질 때, 중앙값을 return 하도록 solution 함수를 완성해보세요.

제한사항

array의 길이는 홀수입니다.
0 < array의 길이 < 100
-1,000 < array의 원소 < 1,000

입출력 예시

arrayresult
[1, 2, 7, 10, 11]7
[9, -1, 0]0

입출력 예시 설명

  • 입출력 예 #1
    본문과 동일합니다.
  • 입출력 예 #2
    9, -1, 0을 오름차순 정렬하면 -1, 0, 9이고 가장 중앙에 위치하는 값은 0입니다.

✅ 해설

def solution(array):
    array.sort()
    a = len(array)
    answer = a // 2
    return array[answer]

3. 최빈값 구하기

✅ 문제 설명

문제 설명

최빈값은 주어진 값 중에서 가장 자주 나오는 값을 의미합니다. 정수 배열 array가 매개변수로 주어질 때, 최빈값을 return 하도록 solution 함수를 완성해보세요. 최빈값이 여러 개면 -1을 return 합니다.

제한사항

0 < array의 길이 < 100
0 ≤ array의 원소 < 1000

입출력 예시

arrayresult
[1, 2, 3, 3, 3, 4]3
[1, 1, 2, 2]-1
[1]1

입출력 예시 설명

  • 입출력 예 #1
    [1, 2, 3, 3, 3, 4]에서 1은 1개 2는 1개 3은 3개 4는 1개로 최빈값은 3입니다.
  • 입출력 예 #2
    [1, 1, 2, 2]에서 1은 2개 2는 2개로 최빈값이 1, 2입니다. 최빈값이 여러 개이므로 -1을 return 합니다.
    입출력 예 #3
  • 입출력 예 #3
    [1]에는 1만 있으므로 최빈값은 1입니다.

✅ 해설

def solution(array):
    while len(array) != 0:
        for i, a in enumerate(set(array)):
            array.remove(a)
        if i == 0:
            return a
    return -1

4. 배열 두 배 만들기

✅ 문제 설명

문제 설명

정수 n이 매개변수로 주어질 때, n 이하의 홀수가 오름차순으로 담긴 배열을 return하도록 solution 함수를 완성해주세요.

제한사항

1 ≤ n ≤ 100

입출력 예시

nresult
10[1, 3, 5, 7, 9]
15[1, 3, 5, 7, 9, 11, 13, 15]
[1]1

입출력 예시 설명

  • 입출력 예 #1
    10 이하의 홀수가 담긴 배열 [1, 3, 5, 7, 9]를 return합니다.
  • 입출력 예 #2
    15 이하의 홀수가 담긴 배열 [1, 3, 5, 7, 9, 11, 13, 15]를 return합니다.

✅ 해설

def solution(n):
    return [i for i in range(n + 1) if i % 2 == 1]

① i
i를 return 해라

② for i in range(n + 1)
근데 그 i는 0부터 n+1 전까지의 범위에 있는 원소들이다.
예를 들어 n이 6이라면 i는 0부터 7전까지인 0, 1, 2, 3, 4, 5, 6이다.

③ if i % 2 == 1
만약 i를 2로 나눈 나머지가 1이라면 (= i가 홀수라면)

profile
인공지능이 인공지능을 개발하면 인공지능일까

0개의 댓글

관련 채용 정보