[백준/Python] 3758 KCPC

DEV Dong's Log·2024년 1월 5일
0

Algorithm

목록 보기
17/37
post-thumbnail

3758번 KCPC

📌Problem

당신은 유명 프로그래밍 대회인 KCPC(Korean Collegiate Programming Contest)에 참가하고 있다. 이 대회에서 총 k개의 문제를 풀게 되는데, 어떤 문제에 대한 풀이를 서버에 제출하면 그 문제에 대해 0점에서 100점 사이의 점수를 얻는다. 풀이를 제출한 팀의 ID, 문제 번호, 점수가 서버의 로그에 제출되는 시간 순서대로 저장된다. 한 문제에 대한 풀이를 여러 번 제출할 수 있는데, 그 중 최고 점수가 그 문제에 대한 최종 점수가 된다. (만약 어떤 문제에 대해 풀이를 한번도 제출하지 않았으면 그 문제에 대한 최종 점수는 0점이다.)

당신 팀의 최종 점수는 각 문제에 대해 받은 점수의 총합이고, 당신의 순위는 (당신 팀보다 높은 점수를 받은 팀의 수)+1 이다.

점수가 동일한 팀이 여럿 있을 수 있는데, 그 경우에는 다음 규칙에 의해서 순위가 정해진다.

  1. 최종 점수가 같은 경우, 풀이를 제출한 횟수가 적은 팀의 순위가 높다.
  2. 최종 점수도 같고 제출 횟수도 같은 경우, 마지막 제출 시간이 더 빠른 팀의 순위가 높다.

동시에 제출되는 풀이는 없고, 모든 팀이 적어도 한 번은 풀이를 제출한다고 가정하라. 서버의 로그가 주어졌을 때, 당신 팀의 순위를 계산하는 프로그램을 작성하시오.

입력

입력 데이터는 표준 입력을 사용한다. 입력은 T개의 테스트 데이터로 구성된다. 입력의 첫 번째 줄에는 테스트 데이터의 수를 나타내는 정수 T가 주어진다. 각 테스트 데이터의 첫 번째 줄에는 팀의 개수 n, 문제의 개수 k, 당신 팀의 ID t, 로그 엔트리의 개수 m을 나타내는 4 개의 정수가 주어진다. 여기서, 3 ≤ n, k ≤ 100, 1 ≤ t ≤ n, 3 ≤ m ≤ 10,000이다. 그 다음 m개의 줄에는 각 풀이에 대한 정보가 제출되는 순서대로 주어진다. 각 줄에는 팀 ID i, 문제 번호 j, 획득한 점수 s를 나타내는 세 개의 정수가 주어진다. 여기서 1 ≤ i ≤ n, 1 ≤ j ≤ k, 0 ≤ s ≤ 100이다.

출력

출력은 표준출력을 사용한다. 주어진 각 테스트 데이터에 대해 당신 팀의 순위를 한 줄에 출력하여야 한다

✍solution

  1. 해당 팀의 문제에 대한 점수를 기록한 배열(arr), 마지막 제출 시간을 담을 배열(times), 문제당 제출 횟수 배열(cnt)을 만든다.
  2. m개의 줄을 순회하며 각 문제에 대한 점수의 최대값, 제출시간, 제출 횟수를 작성한다.
  3. 팀별 점수 합계를 배열 scores에 작성한다.
  4. total_arr 배열에 각 팀별 기록을 작성한다.(팀번호, 점수합계, 제출 시간, 제출 횟수)
  5. 조건에 따라 배열을 정렬하여 문제를 해결한다.

💻Code

T=int(input())
for _ in range(T):
    n, k, t, m = map(int, input().split())
    arr = [[0] * k for _ in range(n)]
    times = [0] * n
    cnt = [0] * n
    for M in range(m):
        i, j, s =map(int, input().split())
        arr[i-1][j-1]=max(arr[i-1][j-1],s)
        cnt[i-1]+=1
        times[i-1]=M+1
    scores = []
    for i in range(n):
        scores.append(sum(arr[i]))
    total_arr = []
    for i in range(n):
        total_arr.append([])
        total_arr[i].append(i+1)
        total_arr[i].append(scores[i])
        total_arr[i].append(cnt[i])
        total_arr[i].append(times[i])

    total_arr.sort(lambda x:(-x[1],x[2],x[3]))
    for i in range(n):
        if total_arr[i][0]==t:
            result = i+1
    print(result)
profile
다양한 분야를 학습하는 프론트엔드 개발자

0개의 댓글