코딩_Python(Level.0)

[Level.0] 수열과 구간 쿼리(2)

Hong's_Computer 2026. 3. 20. 08:55
반응형

문제 설명: 정수 배열 arr와 2차원 정수 배열 queries이 주어집니다. queries의 원소는 각각 하나의 query를 나타내며, [s, e, k] 꼴입니다. 각 query마다 순서대로 s ≤ i ≤ e인 모든 i에 대해 k보다 크면서 가장 작은 arr[i]를 찾습니다. 각 쿼리의 순서에 맞게 답을 저장한 배열을 반환하는 solution 함수를 완성해 주세요. 단, 특정 쿼리의 답이 존재하지 않으면 -1을 저장합니다.

제한사항

  • 1 ≤ arr의 길이 ≤ 1,000
  • 0 ≤ arr의 원소 ≤ 1,000,000
  • 1 ≤ queries의 길이 ≤ 1,000
  • 0 ≤ s ≤ e < arr의 길이
  • 0 ≤ k ≤ 1,000,000

문제 해결

def solution(arr, queries):
    answer = []
    for s, e, k in queries:
        ar = [x for x in arr[s:e+1] if x > k]
        answer.append(-1 if not ar else min(ar))
    return answer

 

주석: 각 쿼리의 범위 내에서 k를 초과하는 원소 중 가장 작은 값을 선별하되 대상이 없으면 -1을 할당

반응형

'코딩_Python(Level.0)' 카테고리의 다른 글

[Level.0] 삼각형의 완성조건(2)  (0) 2026.03.20
[Level.0] 영어가 싫어요  (0) 2026.03.20
[Level.0] 공 던지기  (0) 2026.03.20
[Level.0] 문자열 계산하기  (0) 2026.03.20
[Level.0] 소인수분해  (0) 2026.03.19