프로그래밍/코딩
프로그래머스 - 배열 만들기2
David 리
2024. 7. 1. 23:11
반응형
문제설명>
정수 l과 r이 주어졌을 때, l 이상 r이하의 정수 중에서 숫자 "0"과 "5"로만 이루어진 모든 정수를 오름차순으로 저장한 배열을 return 하는 solution 함수를 완성해 주세요.
만약 그러한 정수가 없다면, -1이 담긴 배열을 return 합니다.
내 생각>
변수 l,r로 for문으로 순회하여, 5의 배수들만 뽑는다.
int를 String으로 Casting하여 각 문자열 하나를 5와 0이 있는지 비교한 후에 List<>에 넣는다.
이때, 중요한 점은 5와 0으로 이루어져 있는지 체크하기 위해 int형 변수 cnt를 초기화했다.
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
28
29
30
31
32
33
34
35
36
37
|
// 배열 만들기
// 5 555 [5, 50, 55, 500, 505, 550, 555]
// 10 20 [-1]
int l = 10;
int r = 20;
int[] answer = {};
String[] strArr = {};
String intToStr = "";
List<Integer> intList = new ArrayList<>();
for (int i = l; i <= r; i++ ) {
if (i % 5 == 0) {
intToStr = i + "";
strArr = intToStr.split("");
// ex) 5
// ex) 1,0
// ex) 5,5
// 5와 0으로 이루어져 있는지 채크하는 변수.
int cnt = 0;
for (int j = 0; j < strArr.length; j++) {
if (strArr[j].equals("0") || strArr[j].equals("5")) {
cnt++;
}
}
// 5와 0으로 이루어져 있으면, 값 담기.
if (cnt == strArr.length) {
intList.add(i);
}
}
}
if (intList.isEmpty()) intList.add(-1);
answer = intList.stream().mapToInt(i -> i).toArray();
System.out.println(Arrays.toString(answer));
|
cs |
반응형