풀이과정
이 문제는 최댓값과 최솟값을 구하는 문제인데 문자열로 주어진다.
그러므로 공백이 나올 때마다 int형 벡터에 넣고, 숫자들을 오름차순으로 정렬해준다.
그럼 v[0]일때 최솟값이 나오고, v[v.size() - 1]일때 최댓값이 나오게 된다.
풀이 1
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
string solution(string s) {
string answer = "";
string str = "";
vector<int> v;
for(int i = 0; i < s.size(); i++){
if(s[i] == ' ') {
v.push_back(stoi(str));
str = "";
}
else str += s[i];
}
if(str != "") v.push_back(stoi(str));
sort(v.begin(), v.end());
answer += to_string(v[0]) + ' ';
answer += to_string(v[v.size() - 1]);
return answer;
}
풀이 2
#include <string>
#include <vector>
using namespace std;
string solution(string s) {
string answer = "";
string str = "";
vector<int> v;
for(int i = 0; i < s.size(); i++){
if(s[i] == ' ') {
v.push_back(stoi(str));
str = "";
}
else str += s[i];
}
if(str != "") v.push_back(stoi(str));
// sort 함수 오름차순 구현
for(int i = 0; i < v.size(); i++){
for(int j = 0; j < v.size(); j++){
if(v[i] < v[j]){
int temp = v[i];
v[i] = v[j];
v[j] = temp;
}
}
}
answer += to_string(v[0]) + ' ';
answer += to_string(v[v.size() - 1]);
return answer;
}
'🍞 Algorithm > Programmers' 카테고리의 다른 글
[프로그래머스][Level2] 카카오 프렌즈 컬러링북 c++ (0) | 2022.10.20 |
---|---|
[프로그래머스][Level2] 최솟값 만들기 c++ (0) | 2022.10.20 |
[프로그래머스][Level2] 의상 c++ (0) | 2022.10.20 |
[프로그래머스][Level2] 숫자의 표현 c++ (0) | 2022.10.20 |
[프로그래머스][Level2] 멀리 뛰기 c++ (0) | 2022.10.20 |