Coding Test - cpp/Sort
[프로그래머스 lv 1 ] - 6주차
에드윈H
2021. 9. 10. 23:59
https://programmers.co.kr/learn/courses/30/lessons/85002
비교를 계속 이상하게 해서 좀 삽질을 했다. 그래서 조건을 저렇게 그대로 다 주석으로 씀
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
struct PlayerInfo
{
PlayerInfo()
{
playerIndex = -1;
winRate = 0.0;
betterMeCnt = 0;
weight = 0;
}
int playerIndex;
double winRate;
int betterMeCnt;
int weight;
};
bool cmp( const PlayerInfo&a, const PlayerInfo&b )
{
//1. 전체 승률이 높은 복서의 번호가 앞쪽으로 갑니다. 아직 다른 복서랑 붙어본 적이 없는 복서의 승률은 0%로 취급합니다.
if( a.winRate > b.winRate )
{
return true;
}
//2 승률이 동일한 복서의 번호들 중에서는 자신보다 몸무게가 무거운 복서를 이긴 횟수가 많은 복서의 번호가 앞쪽으로 갑니다.
if( a.winRate == b.winRate && a.betterMeCnt > b.betterMeCnt )
{
return true;
}
//3. 자신보다 무거운 복서를 이긴 횟수까지 동일한 복서의 번호들 중에서는 자기 몸무게가 무거운 복서의 번호가 앞쪽으로 갑니다.
if( a.winRate == b.winRate && a.betterMeCnt == b.betterMeCnt && a.weight > b.weight )
{
return true;
}
//4. 자기 몸무게까지 동일한 복서의 번호들 중에서는 작은 번호가 앞쪽으로 갑니다.
if( a.winRate == b.winRate && a.betterMeCnt == b.betterMeCnt && a.weight == b.weight && a.playerIndex < b.playerIndex )
{
return true;
}
return false;
}
vector<int> solution( vector<int> weights, vector<string> head2head ) {
int size = head2head.size();
vector<PlayerInfo> players;
for( int i = 0; i < size; i++ )
{
double winCnt = 0;
int better = 0;
double round = 0;
PlayerInfo curPlayer;
for( int j = 0; j < size; j++ )
{
if( i != j )
{
if( head2head[i][j] != 'N' ) //N이 아니여야 라운드진행
{
round++;
}
if( head2head[i][j] == 'W' )//이긴 사람 세기
{
winCnt++;
if( weights[i] < weights[j] )//이긴 사람중 나보다 무거운 사람 세기
{
better++;
}
}
}
}
curPlayer.winRate = winCnt == 0 ? 0.0 : ( winCnt / round ); //이긴횟수가 0번이라면 승률 0%
curPlayer.betterMeCnt = better; //현재선수보다 무거운 사람 몇명인지
curPlayer.weight = weights[i]; //현재선수 몸무게
curPlayer.playerIndex = i + 1; //현재선수 인덱스 번호
players.push_back( curPlayer );
}
vector<int> answer;
//cmp 함수 정렬
sort( players.begin(), players.end(), cmp );
for( auto value : players )
{
answer.push_back( value.playerIndex );
}
return answer;
}