문제 설명


array의 각 element 중 divisor로 나누어 떨어지는 값을 오름차순으로 정렬한 배열을 반환하는 함수, solution을 작성해주세요.
divisor로 나누어 떨어지는 element가 하나도 없다면 배열에 -1을 담아 반환하세요.

제한조건

 

  • arr은 자연수를 담은 배열입니다.
  • 정수 i, j에 대해 i ≠ j 이면 arr[i] ≠ arr[j] 입니다.
  • divisor는 자연수입니다.
  • array는 길이 1 이상인 배열입니다.

 

입출력 예

 

arr divisor return
[5, 9, 7, 10] 5 [5, 10]
[2, 36, 1, 3] 1 [1, 2, 3, 36]
[3,2,6] 10 [-1]

 

입출력 예 설명


입출력 예#1
arr의 원소 중 5로 나누어 떨어지는 원소는 5와 10입니다. 따라서 [5, 10]을 리턴합니다.

입출력 예#2
arr의 모든 원소는 1으로 나누어 떨어집니다. 원소를 오름차순으로 정렬해 [1, 2, 3, 36]을 리턴합니다.

입출력 예#3
3, 2, 6은 10으로 나누어 떨어지지 않습니다. 나누어 떨어지는 원소가 없으므로 [-1]을 리턴합니다.

 

나의 풀이

 

def solution(arr, divisor):
    answer = []
    
    for i in range(len(arr)):
        if arr[i] % divisor == 0:
            answer.append(arr[i])
    if len(answer) == 0:
        answer.append(-1)
    answer.sort()
    return answer

1. arr 배열에서 divisor로 나눠 떨어지는 원소는 리스트 answer에 넣습니다.
2. arr 배열에서 divisor로 나눠 떨어지는 게 아무것도 없는 경우 리스트 answer에 -1을 넣습니다.

3. 리스트 answer를 정렬해서 리턴합니다.

 

다른 사람의 풀이

 

def solution(arr, divisor):
    return sorted([n for n in arr if n%divisor == 0]) or [-1]

arr 배열에서 divisor로 나눠 떨어지는 원소는 정렬해서 리턴하고 만약 값이 없으면 [-1]을 리턴합니다.


프로그래머스 '나누어 떨어지는 숫자 배열' : programmers.co.kr/learn/courses/30/lessons/12910

 

코딩테스트 연습 - 나누어 떨어지는 숫자 배열

array의 각 element 중 divisor로 나누어 떨어지는 값을 오름차순으로 정렬한 배열을 반환하는 함수, solution을 작성해주세요. divisor로 나누어 떨어지는 element가 하나도 없다면 배열에 -1을 담아 반환하�

programmers.co.kr

 

 

문제 설명


배열 arr가 주어집니다. 배열 arr의 각 원소는 숫자 0부터 9까지로 이루어져 있습니다. 이때, 배열 arr에서 연속적으로 나타나는 숫자는 하나만 남기고 전부 제거하려고 합니다. 단, 제거된 후 남은 수들을 반환할 때는 배열 arr의 원소들의 순서를 유지해야 합니다. 예를 들면,

  • arr = [1, 1, 3, 3, 0, 1, 1] 이면 [1, 3, 0, 1] 을 return 합니다.
  • arr = [4, 4, 4, 3, 3] 이면 [4, 3] 을 return 합니다.

배열 arr에서 연속적으로 나타나는 숫자는 제거하고 남은 수들을 return 하는 solution 함수를 완성해 주세요.

 

제한조건

 

  • 배열 arr의 크기 : 1,000,000 이하의 자연수
  • 배열 arr의 원소의 크기 : 0보다 크거나 같고 9보다 작거나 같은 정수

입출력 예

 

arr answer
[1,1,3,3,0,1,1] [1,3,0,1]
[4,4,4,3,3] [4,3]

 

입출력 예 설명


입출력 예 #1,2
문제의 예시와 같습니다.

나의 풀이

 

def solution(arr):
    answer=[]
    for i in range(1,len(arr)):
        if arr[i-1] != arr[i]:
            answer.append(arr[i-1])
    answer.append(arr[-1])
    
    return answer

1. 배열 arr의 앞자리와 뒷자리의 원소를 비교하여 서로 다르면 뒷자리의 원소를 리스트 answer에 추가합니다.
2. 배열 arr의 마지막 원소도 리스트 answer에 추가합니다.

 


프로그래머스 '같은 숫자는 싫어' : programmers.co.kr/learn/courses/30/lessons/12906

 

코딩테스트 연습 - 같은 숫자는 싫어

배열 arr가 주어집니다. 배열 arr의 각 원소는 숫자 0부터 9까지로 이루어져 있습니다. 이때, 배열 arr에서 연속적으로 나타나는 숫자는 하나만 남기고 전부 제거하려고 합니다. 단, 제거된 후 남은

programmers.co.kr

 

문제 설명


단어 s의 가운데 글자를 반환하는 함수, solution을 만들어 보세요. 단어의 길이가 짝수라면 가운데 두글자를 반환하면 됩니다.

제한조건

 

  • s는 길이가 1 이상, 100이하인 스트링입니다.

 

입출력 예

 

s return
'abcde' 'c'
'qwer' 'we'

 

나의 풀이

 

def solution(s):
    a = len(s) // 2
    if len(s) % 2 == 0:
        return s[a-1:a+1]
    else:
        return s[a]

1. 문자열의 길이를 2로 나눠 짝수인 경우 두글자를 출력하고 홀수인 경우 한글자를 출력합니다.

다른 사람의 풀이

 

def solution(s):
	return s[(len(s)-1)//2:len(s)//2+1]

짝수인 경우 두글자를 출력하고 홀수인 경우 한글자를 출력합니다.

 


프로그래머스 '가운데 글자 가져오기' : programmers.co.kr/learn/courses/30/lessons/12903

 

코딩테스트 연습 - 가운데 글자 가져오기

단어 s의 가운데 글자를 반환하는 함수, solution을 만들어 보세요. 단어의 길이가 짝수라면 가운데 두글자를 반환하면 됩니다. 재한사항 s는 길이가 1 이상, 100이하인 스트링입니다. 입출력 예 s ret

programmers.co.kr

 

문제 설명


2016년 1월 1일은 금요일입니다. 2016년 a월 b일은 무슨 요일일까요? 두 수 a ,b를 입력받아 2016년 a월 b일이 무슨 요일인지 리턴하는 함수, solution을 완성하세요. 요일의 이름은 일요일부터 토요일까지 각각 SUN,MON,TUE,WED,THU,FRI,SAT

입니다. 예를 들어 a=5, b=24라면 5월 24일은 화요일이므로 문자열 TUE를 반환하세요.

 

제한조건

 

  • 2016년은 윤년입니다.
  • 2016년 a월 b일은 실제로 있는 날입니다. (13월 26일이나 2월 45일같은 날짜는 주어지지 않습니다)

 

입출력 예

 

a b result
5 24 'TUE'

 

나의 풀이

 

def solution(a, b):
    y =[31,29,31,30,31,30,31,31,30,31,30,31 ]
    n=['FRI','SAT','SUN','MON','TUE','WED','THU']
    k=sum(y[:a-1]) + b-1
    return n[k % 7]

각 요일의 이름과 달의 마지막 날짜를 리스트로 저장합니다.
a월 b일을 구하기 위해 a달 전까지의 날짜를 더하고 b일을 더해줍니다.

(1월 1일은 금요일이니까 하루 계산해주었기 때문에 -1 하기)

계산한 날짜로 요일의 수인 7을 나눠 값을 구합니다.

 


프로그래머스 '2016년' : programmers.co.kr/learn/courses/30/lessons/12901

 

코딩테스트 연습 - 2016년

2016년 1월 1일은 금요일입니다. 2016년 a월 b일은 무슨 요일일까요? 두 수 a ,b를 입력받아 2016년 a월 b일이 무슨 요일인지 리턴하는 함수, solution을 완성하세요. 요일의 이름은 일요일부터 토요일까��

programmers.co.kr

 

문제 설명


배열 array의 i번째 숫자부터 j번째 숫자까지 자르고 정렬했을 때, k번째에 있는 수를 구하려 합니다.

예를 들어 array가 [1, 5, 2, 6, 3, 7, 4], i = 2, j = 5, k = 3이라면

  1. array의 2번째부터 5번째까지 자르면 [5, 2, 6, 3]입니다.
  2. 1에서 나온 배열을 정렬하면 [2, 3, 5, 6]입니다.
  3. 2에서 나온 배열의 3번째 숫자는 5입니다.

배열 array, [i, j, k]를 원소로 가진 2차원 배열 commands가 매개변수로 주어질 때, commands의 모든 원소에 대해 앞서 설명한 연산을 적용했을 때 나온 결과를 배열에 담아 return 하도록 solution 함수를 작성해주세요.

 

제한조건

 

  • array의 길이는 1 이상 100 이하입니다.
  • array의 각 원소는 1 이상 100 이하입니다.
  • commands의 길이는 1 이상 50 이하입니다.
  • commands의 각 원소는 길이가 3입니다.

 

입출력 예

 

array commands return
[1, 5, 2, 6, 3, 7, 4] [[2, 5, 3], [4, 4, 1], [1, 7, 3]] [5, 6, 3]

 

입출력 예 설명


[1, 5, 2, 6, 3, 7, 4]를 2번째부터 5번째까지 자른 후 정렬합니다. [2, 3, 5, 6]의 세 번째 숫자는 5입니다.
[1, 5, 2, 6, 3, 7, 4]를 4번째부터 4번째까지 자른 후 정렬합니다. [6]의 첫 번째 숫자는 6입니다.
[1, 5, 2, 6, 3, 7, 4]를 1번째부터 7번째까지 자릅니다. [1, 2, 3, 4, 5, 6, 7]의 세 번째 숫자는 3입니다.

나의 풀이

 

def solution(array, commands):
    answer = []
    for i in range(len(commands)):
        s = commands[i][0] - 1
        e = commands[i][1] - 1
        k = commands[i][2] - 1
        
        a=array[s:e+1]
        a.sort()
        answer.append(a[k])
    
    return answer

1. commands의 2차원 배열에서 s, e, k를 구합니다.
2. array 배열을 s부터 e번째 숫자까지 자르고 정렬한 후 k번째 있는 수를 구해 리스트 answer에 넣어줍니다.
3. 1, 2번을 반복하고 마지막에 리스트 answer를 리턴합니다.

 

다른 사람의 풀이

 

def solution(array, commands):
    return list(map(lambda x:sorted(array[x[0]-1:x[1]])[x[2]-1], commands))

array 배열에서 x[0]-1번부터 x[1]-1번까지 자르고 정렬을 시킵니다.
정렬시킨 배열에서 x[2]-1번 위치의 값을 구합니다.

commands에서 이 과정을 해주고 리스트로 리턴합니다.

 


프로그래머스 'K번째수' : programmers.co.kr/learn/courses/30/lessons/42748

 

코딩테스트 연습 - K번째수

[1, 5, 2, 6, 3, 7, 4] [[2, 5, 3], [4, 4, 1], [1, 7, 3]] [5, 6, 3]

programmers.co.kr

 

문제 설명


점심시간에 도둑이 들어, 일부 학생이 체육복을 도난당했습니다. 다행히 여벌 체육복이 있는 학생이 이들에게 체육복을 빌려주려 합니다. 학생들의 번호는 체격 순으로 매겨져 있어, 바로 앞번호의 학생이나 바로 뒷번호의 학생에게만 체육복을 빌려줄 수 있습니다. 예를 들어, 4번 학생은 3번 학생이나 5번 학생에게만 체육복을 빌려줄 수 있습니다. 체육복이 없으면 수업을 들을 수 없기 때문에 체육복을 적절히 빌려 최대한 많은 학생이 체육수업을 들어야 합니다.

전체 학생의 수 n, 체육복을 도난당한 학생들의 번호가 담긴 배열 lost, 여벌의 체육복을 가져온 학생들의 번호가 담긴 배열 reserve가 매개변수로 주어질 때, 체육수업을 들을 수 있는 학생의 최댓값을 return 하도록 solution 함수를 작성해주세요.

 

제한조건

 

  • 전체 학생의 수는 2명 이상 30명 이하입니다.
  • 체육복을 도난당한 학생의 수는 1명 이상 n명 이하이고 중복되는 번호는 없습니다.
  • 여벌의 체육복을 가져온 학생의 수는 1명 이상 n명 이하이고 중복되는 번호는 없습니다.
  • 여벌 체육복이 있는 학생만 다른 학생에게 체육복을 빌려줄 수 있습니다.
  • 여벌 체육복을 가져온 학생이 체육복을 도난당했을 수 있습니다. 이때 이 학생은 체육복을 하나만 도난당했다고 가정하며, 남은 체육복이 하나이기에 다른 학생에게는 체육복을 빌려줄 수 없습니다.

 

입출력 예

 

n lost reserve return
5 [2, 4] [1, 3, 5] 5
5 [2, 4] [3] 4
3 [3] [1] 2

 

입출력 예 설명


예제 #1
1번 학생이 2번 학생에게 체육복을 빌려주고, 3번 학생이나 5번 학생이 4번 학생에게 체육복을 빌려주면 학생 5명이 체육수업을 들을 수 있습니다.

예제 #2
3번 학생이 2번 학생이나 4번 학생에게 체육복을 빌려주면 학생 4명이 체육수업을 들을 수 있습니다.

 

나의 풀이

 

def solution(n, lost, reserve):
    a = set(reserve)-set(lost)
    b = len(lost)
    if len(a) == len(reserve):
        c = 0
    else:
        c = len(reserve) - len(a)
        lost = set(lost) - (set(reserve) - set(a))
    
    for i in a:
        if len(lost) == 0:
            break
        
        if i - 1 in lost:
            c += 1
            lost.remove(i - 1)
        elif i + 1 in lost:
            c += 1
            lost.remove(i + 1)
            
    if n - b + c > n:
        return n
    else:
        return n - b + c

1. set을 통해 reverse와 lost의 차집합을 구해줍니다. (겹치는 숫자가 있는지 검사해서 a에 넣기)

2. reserve에서 lost에 겹치지 않는 것(a)을 비교하는데 바로 앞번호의 학생이나 바로 뒷번호의 학생에게만 체육복을 빌려줄 수 있기 때문에 앞번호나 뒷번호에 체육복을 잃어버렸으면 빌려준 학생수를 올려주고 잃어버린 항목에서 해당 학생을 지워줍니다.

3. 모든 학생이 체육복을 빌릴 수 있으면 전체 학생수 n을 출력하고 아니면 빌릴 수 있는 최대 학생수를 출력해줍니다.

 

다른 사람의 풀이

 

def solution(n, lost, reserve):
    _reserve = [r for r in reserve if r not in lost]
    _lost = [l for l in lost if l not in reserve]
    for r in _reserve:
        f = r - 1
        b = r + 1
        if f in _lost:
            _lost.remove(f)
        elif b in _lost:
            _lost.remove(b)
    return n - len(_lost)

리스트 _reserve와 _lost를 새로 만들어줍니다.
_reserve 요소의 앞번호나 뒷번호가 체육복을 잃어버렸으면 빌려준 학생수를 올려주고 잃어버린 항목에서 해당 학생을 지워줍니다.

전체 학생에서 체육복을 빌리지 못한 학생수를 빼서 출력해줍니다.

 


프로그래머스 '체육복' : programmers.co.kr/learn/courses/30/lessons/42862

 

코딩테스트 연습 - 체육복

점심시간에 도둑이 들어, 일부 학생이 체육복을 도난당했습니다. 다행히 여벌 체육복이 있는 학생이 이들에게 체육복을 빌려주려 합니다. 학생들의 번호는 체격 순으로 매겨져 있어, 바로 앞번�

programmers.co.kr

 

 

+ Recent posts