[프로그래머스/C++ 문제 풀이] Lv. 0 - 등수 매기기

2024. 7. 5. 16:12·코딩테스트/프로그래머스 (Lv. 0)
728x90
반응형

문제 설명

영어 점수와 수학 점수의 평균 점수를 기준으로 학생들의 등수를 매기려고 합니다. 영어 점수와 수학 점수를 담은 2차원 정수 배열 score가 주어질 때, 영어 점수와 수학 점수의 평균을 기준으로 매긴 등수를 담은 배열을 return하도록 solution 함수를 완성해주세요.

제한 사항

  • 0 ≤ score[0], score[1] ≤ 100
  • 1 ≤ score의 길이 ≤ 10
  • score의 원소 길이는 2입니다.
  • score는 중복된 원소를 갖지 않습니다.

입출력 예

score result
[[80, 70], [90, 50], [40, 70], [50, 80]] [1, 2, 4, 3]
[[80, 70], [70, 80], [30, 50], [90, 100], [100, 90], [100, 100], [10, 30]] [4, 4, 6, 2, 2, 1, 7]

 

입출력 예 #1

  • 평균은 각각 75, 70, 55, 65 이므로 등수를 매겨 [1, 2, 4, 3]을 return합니다.

입출력 예 #2

  • 평균은 각각 75, 75, 40, 95, 95, 100, 20 이므로 [4, 4, 6, 2, 2, 1, 7] 을 return합니다.
  • 공동 2등이 두 명, 공동 4등이 2명 이므로 3등과 5등은 없습니다.

문제 풀이

이번 문제의 경우 score의 사이즈가 최대 10까지 밖에 안되기에 저는 이중 for문을 통해 모든 평균값을 비교해가며 문제를 해결하게 되었습니다.

 

주어진 점수는 int로, 평균값을 계산했을 때 소수 부분이 포함되면 순위의 변동이 생길수도 있기에 float 형으로 강제 형변환을 진행하여 평균값을 계산하였습니다.

 

문제를 통과한 이후 생각해보니 굳이 평균값을 구할 필요가 없다는 아이디어가 생각났습니다.

즉, 영어 점수와 수학 점수를 합친 값으로 비교를 해도 동일한 결과가 나오게 된다는 것입니다.

정답 코드

더보기
#include <string>
#include <vector>

using namespace std;

vector<int> solution(vector<vector<int>> score) {
    vector<int> answer;

    for (int i = 0; i < score.size(); i++)
    {
        float avg = (score[i][0] + score[i][1]) / 2.0f;
        int index = 1;
        for (int j = 0; j < score.size(); j++)
        {
            if (i == j) continue;

            float nextAvg = (score[j][0] + score[j][1]) / 2.0f;

            if (nextAvg > avg)
            {
                index++;
            }
        }

        answer.push_back(index);
    }

    return answer;
}
728x90
반응형
저작자표시 비영리 변경금지 (새창열림)

'코딩테스트 > 프로그래머스 (Lv. 0)' 카테고리의 다른 글

[프로그래머스/C++ 문제 풀이] Lv. 0 - 로그인 성공?  (0) 2024.07.08
[프로그래머스/C++ 문제 풀이] Lv. 0 - 치킨 쿠폰  (0) 2024.07.05
[프로그래머스/C++ 문제 풀이] Lv. 0 - 유한 소수 판별하기  (0) 2024.07.05
[프로그래머스/C++ 문제 풀이] Lv. 0 - 저주의 숫자 3  (0) 2024.07.03
[프로그래머스/C++ 문제 풀이] Lv. 0 - 특이한 정렬  (0) 2024.07.02
'코딩테스트/프로그래머스 (Lv. 0)' 카테고리의 다른 글
  • [프로그래머스/C++ 문제 풀이] Lv. 0 - 로그인 성공?
  • [프로그래머스/C++ 문제 풀이] Lv. 0 - 치킨 쿠폰
  • [프로그래머스/C++ 문제 풀이] Lv. 0 - 유한 소수 판별하기
  • [프로그래머스/C++ 문제 풀이] Lv. 0 - 저주의 숫자 3
리태s
리태s
게임 클라이언트 프로그래머 직무를 준비하며 공부한 내용을 정리한 블로그입니다.
    반응형
    250x250
  • 리태s
    LeeTaes 공부노트
    리태s
  • 전체
    오늘
    어제
    • Home (165)
      • 프로젝트 (20)
        • Isaac 3D (5)
        • TimelessAdventure (13)
        • FruitsPuzzle (2)
      • Game Programming (25)
        • C# (8)
        • Unity Engine (6)
        • Unreal Engine (8)
        • UE_Multiplayer (3)
      • 코딩테스트 (111)
        • 프로그래머스 (Lv. 0) (27)
        • 프로그래머스 (Lv. 1) (31)
        • 프로그래머스 (Lv. 2) (21)
        • 백준 (Study) (29)
        • 알고리즘 (3)
      • CS지식 (7)
        • 운영체제 (7)
      • 일상 (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    issac3d
    후기
    delegate
    구현
    project t.a develop
    fruitspuzzle
    c#
    fsoftobjectpath
    CS지식
    코딩테스트
    프로그래머스
    dataasset
    unrealengine
    timelessadventure
    Unreal Engine
    프로세스
    청년취업사관학교
    Summer/Winter Coding
    프로젝트
    sesac
    pcce 기출문제
    2019 kakao
    2022 kakao
    ai controller
    백준
    C++
    Algorithm
    2018 kakao
    tsoftobjectptr
    unity
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
리태s
[프로그래머스/C++ 문제 풀이] Lv. 0 - 등수 매기기
상단으로

티스토리툴바