티스토리 뷰

알고리즘

코테 / 자동차 테스트(python)

삼전동해커 2023. 9. 4. 23:52
문제

자동차 제조 과정에서는 다양한 테스트를 통해 해당 자동차가 잘 만들어졌는지를 평가합니다.

이러한 평가 지표 중 하나는 자동차의 연비입니다.

자동차의 연비가 높을수록 연료 소비가 적고, 더 많은 거리를 주행할 수 있으므로 이는 자동차가 잘 만들어졌는지의 지표로 사용될 수 있습니다.

만약 3대의 자동차를 테스트하고, 각각의 연비를 측정한다고 가정해봅시다.

첫 번째 자동차의 연비는 9km/L,

두 번째 자동차의 연비는 15km/L,

세 번째 자동차의 연비는 20km/L이라고 합시다.

이 경우, 중앙값은 15km/L이 됩니다.

 

따라서 이 데이터에서는 중앙값을 이용하여 자동차의 평균적인 연비를 파악할 수 있으며,

이는 자동차 제조 과정에서 테스트의 결과를 평가하는 데 활용될 수 있습니다.

n대의 자동차를 새로 만들었지만 여건상 3대의 자동차에 대해서만 테스트가 가능한 상황입니다.

n대의 자동차의 실제 연비 값이 주어졌을 때, q개의 질의에 대해 임의로 3대의 자동차를 골라 테스트하여 중앙값이 mi값이 나오는 서로 다른 경우의 수를 구하는 프로그램을 작성해보세요.

제약조건

* 1 ≤ n ≤ 50,000
* 1 ≤ q ≤ 200,000
* 1 ≤ 자동차의 연비 ≤ 1,000,000,000
* 1 ≤ mi ≤ 1,000,000,000 (i는 1 이상 q 이하입니다. 즉, mi 는 각 질의에 대응하는 중앙값을 의미합니다.)

입력형식

첫 번째 줄에 n, q가 공백을 사이에 두고 주어집니다.


두 번째 줄에는 n개의 자동차의 연비에 해당하는 값이 공백을 사이에 두고 주어집니다.

주어지는 자동차의 연비는 서로 다름을 가정해도 좋습니다.

세 번째 줄부터는 q개의 줄에 걸쳐 테스트 결과로 기대하는 값인 mi가 한 줄에 하나씩 주어집니다.

출력형식

q개의 줄에 걸쳐 3대의 자동차를 골랐을 때 연비의 중앙값이 mi가 나오는 서로 다른 가짓수를 한 줄에 하나씩 출력합니다.

입력예제1
5 3
5 2 3 1 6
1
3
6
출력예제1
0
4
0
입력예제2
6 8
7 4 3 2 6 1
1
2
3
4
5
6
7
1000000000
출력예제2
0
4
6
6
0
4
0
0

풀이법

간단한 설명으로는 타겟 값(중앙값)보다 작은 값의 개수 * 타겟값 보다 큰 값의 개수 = 경우의 수이다.

먼저 연비 리스트를 sorted()하고, 이진 탐색으로 타겟 값을 찾는다. 찾은 타겟 값보다 작은 개수 * 큰 개수 하면 된다.

 

입력 받기

n, q = map(int, sys.stdin.readline().split())
n_list = list(map(int, sys.stdin.readline().split()))

정렬하기

n_list = sorted(n_list)
case_list = list()

이진 탐색 구현

def binary_search (arr, target, start, end):
    
    if start > end:
        return None
    
    mid = (start + end) // 2

    if arr[mid] == target:
        return mid

    elif arr[mid] > target:
        return binary_search(arr, target, start, mid-1)
        
    else:
        return binary_search(arr, target, mid+1, end)

q개의 질의에 대해 경우의 수 구하기

for i in range(0,q):
    target_raw = int(input())
    
    tmp = binary_search(n_list, target_raw, 0, n-1)
    if tmp == None or tmp == 0:
        case_list.append(0)
    else:
        res = tmp * (n - tmp - 1)
        case_list.append(res)

출력하기

for i in range(0,len(case_list)):
    print(str(case_list[i]))

전체 코드

import sys

def binary_search (arr, target, start, end):
    
    if start > end:
        return None

    mid = (start + end) // 2

    if arr[mid] == target:
        return mid

    elif arr[mid] > target:
        return binary_search(arr, target, start, mid-1)
        
    else:
        return binary_search(arr, target, mid+1, end)
    
    
n, q = map(int, sys.stdin.readline().split())
n_list = list(map(int, sys.stdin.readline().split()))
n_list = sorted(n_list)
case_list = list()

for i in range(0,q):
    target_raw = int(input())

    tmp = binary_search(n_list, target_raw, 0, n-1)
    # print(tmp)
    if tmp == None or tmp == 0:
        case_list.append(0)

    else:
        res = tmp * (n - tmp - 1)
        case_list.append(res)


for i in range(0,len(case_list)):
    print(str(case_list[i]))

'알고리즘' 카테고리의 다른 글

코테 / 프로그래머스 타겟 넘버(재귀함수 이해하기)  (1) 2023.09.07
코테 / C++ input 받는 방법  (0) 2023.09.05
합병 정렬 알고리즘  (0) 2021.10.18
퀵 정렬 알고리즘  (0) 2021.10.18
삽입 정렬 알고리즘  (0) 2021.10.18
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함