nayoungs
항상 끈기있게
nayoungs
  • 분류 전체보기 (274)
    • Cloud (21)
      • AWS (15)
      • Azure (3)
      • NCP (2)
      • GCP (1)
    • DevOps (68)
      • Docker (16)
      • Kubernetes (50)
      • CICD (2)
    • IaC (25)
      • Ansible (17)
      • Terraform (8)
    • Certification (4)
    • 금융 IT (5)
    • AI (3)
    • Linux (47)
    • 미들웨어 (5)
    • Programming (7)
      • GoLang (3)
      • Spring (4)
    • CS (25)
      • 네트워크 (17)
      • 운영체제 (5)
      • Web (1)
      • 개발 상식 (2)
      • 데이터베이스 (0)
    • Algorithm (59)
      • 프로그래머스 (36)
      • 백준 (18)
      • 알고리즘 정리 (5)
    • ETC (5)

블로그 메뉴

  • 홈
  • 방명록

공지사항

인기 글

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
nayoungs

항상 끈기있게

Algorithm/프로그래머스

(C++) 프로그래머스 level2 : 최댓값과 최솟값

2022. 2. 10. 19:55
728x90

문제 설명

 

문자열 s에는 공백으로 구분된 숫자들이 저장되어 있습니다. str에 나타나는 숫자 중 최소값과 최대값을 찾아 이를 "(최소값) (최대값)"형태의 문자열을 반환하는 함수, solution을 완성하세요.

예를들어 s가 "1 2 3 4"라면 "1 4"를 리턴하고, "-1 -2 -3 -4"라면 "-4 -1"을 리턴하면 됩니다.

 

제한 조건

 

s에는 둘 이상의 정수가 공백으로 구분되어 있습니다.

 

 

입출력 예

 
s
return
"1 2 3 4"
"1 4"
"-1 -2 -3 -4"
"-4 -1"
"-1 -1"
"-1 -1"

 

출처: https://programmers.co.kr/learn/courses/30/lessons/12939


처음에 테스트케이스는 모두 통과했으나, 채점결과는 틀려서 당황했는데

숫자가 두자리 수인 경우를 생각하지 못해서 그랬었다

 

한자리 숫자를 처리하는 방법과 두자리 숫자를 처리하는 방법은 완전히 다르기 때문에

소스코드를 다시 작성해야했다..

 

 

#include <string>
#include <algorithm>
#include <vector>
using namespace std;

string solution(string s) {

    vector<string>stringNums;
    int t = 0;
    while (t< s.length())
    {
        string str = "";
        while (t < s.length())
        {
            if (s[t] == ' ') break;
            str += s[t++];
        }
        stringNums.push_back(str);
        t++;
    }
    vector<int>nums;
    for (int i = 0; i < stringNums.size(); i++)
        nums.push_back(stoi(stringNums[i]));//문자열을 int로 변환
    sort(nums.begin(), nums.end());
    
    string answer = to_string(nums[0]) + " " + to_string(nums[nums.size() - 1]);
  
    return answer;
}
 
풀이

반복문을 통해 공백이 직전까지 문자들을 더해서 vector에 push해주었다.

그리고 문자열을 int형 정수로 변환한 뒤 sort(오름차순) 후에 가장 첫번째 원소(최솟값) 과 마지막 원소(최댓값) 를 다시 문자열로 변환 한뒤 공백을 추가하여 return해주었다.

 

 

 

 

728x90
저작자표시 (새창열림)
    'Algorithm/프로그래머스' 카테고리의 다른 글
    • (C++) 프로그래머스 level2 : 카펫
    • (C++) 프로그래머스 level2 : 게임 맵 최단거리
    • (C++) 프로그래머스 level2 : 가장 큰 수
    • (C++) 프로그래머스 level2 : 타겟 넘버
    nayoungs
    nayoungs
    안되면 될 때까지

    티스토리툴바