소스 코드

T = int(input())

for tc in range(1,1+T):

    # 종로 거리의 길이, 말의 수
    d,n = map(int,input().split())

    # [말 위치, 속도]
    horse = [list(map(int,input().split())) for _ in range(n)]

    # 종로 거리가 끝나는 곳에서 가까운 순으로 정렬
    horse.sort(key=lambda x : x[0], reverse=True)

    # 말의 이동시간
    cnt = 0

    for q in horse:

        # (종로 거리의 길이 - 말의 위치)/말의 속도 == a
        # a가 현재 저장된 이동 시간보다 크면 cnt 값 바꾸기
        # 말을 추월하거나 자율주행차의 속도를 늦추지 않기 위해서는 말과 만나면 안 된다
        # cnt에 이동시간이 가장 긴 말의 이동시간을 저장해둬야 함
        if (d-q[0])/q[1] > cnt:
            cnt = (d-q[0])/q[1]

    # 가능한 최대 속도 = 거리의 길이 / 말의 이동시간
    res = d/cnt

    # {:0<9} 이란, 출력을 위한 9칸을 만들고 해당 칸에 res를 출력
    # 만일 res가 9칸이 안 된다면 나머지(오른쪽으로)는 0으로 채우기
    print('#{} {:0<9}'.format(tc,res))

 


해결 방법

1. 말이 종로 거리의 끝에 도착하는 최장시간을 구해야 함

(자율주행차의 최대 속도는 말의 최장 이동시간을 기준으로 정할 수 있기 때문)

 

2. 말끼리 만날 경우, 앞선 말의 뒤에 서는 것이 아닌 나란히 선다고 이해해야 함

(2번째 tc의 경우 뒤에 선다고 생각하면 20.2가 나올 수 없음)

 

3. 출력 값은 정수+소수 9자리이다

(만일 정수의 값이 100,000인 경우 출력은 100,000.000이고, 정수가 0 소수가 0.1인 경우 출력은 0.00000001 이 될 것임)


느낀 점

 

 

ps. 개인적인 코드와 코드를 작성의 이유를 적은 것입니다.

 

오류적절치 않은 문법이 존재할 수 있으며, 다른 분들께는 굉장히 비효율적인 방법으로 여겨질 수 있습니다.

 

혹시 개선 사항, 오류 및 문제에 대한 수정 사항 등을 댓글로 남겨주신다면 감사한 마음으로 배우고 수정하겠습니다.