코딩테스트 연습 > PCCE 기출문제 > [PCCE 기출문제] 10번 / 데이터 분석
[PCCE 기출문제] 10번 / 데이터 분석 Lv.1
AI 엔지니어인 현식이는 데이터를 분석하는 작업을 진행하고 있습니다.
데이터는 ["코드 번호(code)", "제조일(date)", "최대 수량(maximum)", "현재 수량(remain)"]으로 구성되어 있으며 현식이는 이 데이터들 중 조건을 만족하는 데이터만 뽑아서 정렬하려 합니다.
data와 어떤 정보를 기준으로 데이터를 뽑아낼지를 의미하는 문자열 ext, 뽑아낼 정보의 기준값을 나타내는 정수 val_ext, 정보를 정렬할 기준이 되는 문자열 sort_by가 주어집니다.
data에서 ext 값이 val_ext보다 작은 데이터만 뽑은 후, sort_by에 해당하는 값을 기준으로 오름차순으로 정렬하여 return 하도록 solution 함수를 완성해 주세요. 단, 조건을 만족하는 데이터는 항상 한 개 이상 존재합니다.
[제한사항]
- 1 ≤ data의 길이 ≤ 500
- data[i]의 원소는 [코드 번호(code), 제조일(date), 최대 수량(maximum), 현재 수량(remain)] 형태입니다.
- 1 ≤ 코드 번호≤ 100,000
- 20000101 ≤ 제조일≤ 29991231
- data[i][1]은 yyyymmdd 형태의 값을 가지며, 올바른 날짜만 주어집니다. (yyyy : 연도, mm : 월, dd : 일)
- 1 ≤ 최대 수량≤ 10,000- 1 ≤ 현재 수량≤ 최대 수량
- ext와 sort_by의 값은 다음 중 한 가지를 가집니다.
- "code", "date", "maximum", "remain"
- 순서대로 코드 번호, 제조일, 최대 수량, 현재 수량을 의미합니다.
- val_ext는 ext에 따라 올바른 범위의 숫자로 주어집니다.
- 정렬 기준에 해당하는 값이 서로 같은 경우는 없습니다.
첫 번째 풀이 : 100점
def solution(data, ext, val_ext, sort_by):
answer = []
lst = ['code', 'date', 'maximum', 'remain']
t = lst.index(ext)
for i in range(len(data)):
if data[i][t] < val_ext:
answer.append(data[i])
answer.sort(key=lambda x : x[lst.index(sort_by)])
return answer
- .sort(key=lambda x : x[lst.index(sort_by)])
'코딩테스트 | python > 프로그래머스' 카테고리의 다른 글
| [프로그래머스 | python] 짝수와 홀수 (0) | 2024.02.29 |
|---|---|
| [프로그래머스 | python] 개인정보 수집 유효기간 (0) | 2024.02.29 |
| [프로그래머스 | python] 피보나치 수 (0) | 2024.02.27 |
| [프로그래머스 | python] 숫자 변환하기 (0) | 2024.02.27 |
| [프로그래머스 | python] 최소직사각형 (0) | 2024.02.27 |