새벽코딩

[프로그래머스] 최댓값과 최솟값 (JAVA) (level2) 본문

알고리즘

[프로그래머스] 최댓값과 최솟값 (JAVA) (level2)

J 코딩 2023. 7. 26. 10:15
반응형

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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr


문제 설명

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

제한 조건
  • s에는 둘 이상의 정수가 공백으로 구분되어 있습니다.
입출력 예sreturn
"1 2 3 4" "1 4"
"-1 -2 -3 -4" "-4 -1"
"-1 -1" "-1 -1"

※ JAVA 코드 (최댓값과 최솟값)

import java.io.*;

class Solution {
    public String solution(String s) {
        String answer = "";
        String[] arr = s.split(" ");

        int minVal = Integer.parseInt(arr[0]);
        int maxval = Integer.parseInt(arr[0]);

        for(int i = 1; i < arr.length; i++) {
            int num = Integer.parseInt(arr[i]);
            if(minVal > num){
                minVal = num;
            }
            if(maxval < num){
                maxval = num;
            }
        }
        answer += minVal + " " + maxval;

        return answer;
    }
}

※ 생각정리 (최댓값과 최솟값)

1. split을 이용해 문자를 잘라서 맨처음 값을 변수에 담는다.

String[] arr = s.split(" ");

int minVal = Integer.parseInt(arr[0]);
int maxval = Integer.parseInt(arr[0]);

 

2. 최솟값과 최댓값을 비교하며 갱신한다.

if(minVal > num){
    minVal = num;
}
if(maxval < num){
    maxval = num;
}

 

단순 숫자 비교를 통한 쉬운 문제였습니다.

 

 

-새벽코딩-

반응형
Comments