Post

Programmers_sort02 - 가장 큰 수

프로그래머스 - 가장 큰 수 문제 입니다.

1. 문제

https://programmers.co.kr/learn/courses/30/parts/12077


2. 분류 및 난이도

Programmers 문제입니다.
level 2의 문제입니다.


3. 생각한 것들(문제 접근 방법)

  • 생각 자체는 어렵지 않았습니다. 배열을 돌면서 주어진 정렬 조건대로 answer에 추가해주었습니다.
  • 인풋으로 0이 들어올 경우를 예외처리 해주었습니다.

4. 접근 방법을 적용한 코드

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
#include <string>
#include <vector>
#include<iostream>
#include<algorithm>
using namespace std;

bool pred(string& a, string& b)
{
	return a + b > b + a;
}


string solution(vector<int> numbers) {
	string answer = "";
	vector<string> vec;
	for (size_t i = 0; i < numbers.size(); ++i)
	{
		vec.push_back(to_string(numbers[i]));	
	}
	sort(vec.begin(), vec.end(),pred);
	for (size_t i = 0; i < numbers.size(); ++i)
		answer += vec[i];

    if(answer[0]=='0')
        answer='0';
	return answer;
}

5. 결과

This post is licensed under CC BY 4.0 by the author.