시작은 쉬운 문제로 가야맞다
문제 설명
문자열 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" |
Solution.java
import java.util.*;
class Solution {
public String solution(String s) {
String answer = "";
int[] numbers = Arrays.stream(s.split(" "))
.mapToInt(Integer::parseInt)
.toArray();
int max = Arrays.stream(numbers).max().getAsInt();
int min = Arrays.stream(numbers).min().getAsInt();
answer = min +" "+ max;
return answer;
}
}
풀이
더보기
예전이었으면 for문을 이용해서 만들었겠지만
Array 함수를 이용하면 쉽게 짤 수 있다.
일단, 문자열로 받아서 구분자 기준으로 문자열 배열로 만든 다음
map 함수를 이용해 int 배열로 바꿔준다.
그 다음 최대값 최소값만 뽑아내면 끝
출처 :: 프로그래머스 코딩 테스트 연습
'알고리즘' 카테고리의 다른 글
| 프로그래머스 Lv1. K번째 수 - Java (0) | 2021.07.02 |
|---|---|
| [프로그래머스] Lv2. 프린터 - Java (0) | 2021.02.17 |
| [프로그래머스] Lv2. 스킬트리 - Java (0) | 2021.02.16 |
| [프로그래머스] Lv2. 다리를 지나는 트럭 - Java (0) | 2021.02.15 |
| [프로그래머스] Lv2. 멀쩡한 사각형 - Java (0) | 2021.02.03 |