나의 풀이
class Solution {
public int solution(int order) {
int cnt=0;
String str = order+"";
char[] chars=str.toCharArray();
for(int i=0; i<chars.length; i++){
if(chars[i]=='3') cnt++;
if(chars[i]=='6') cnt++;
if(chars[i]=='9') cnt++;
}
return cnt;
}
}
▶ int타입 order에 빈문자열("")을 더해서 String타입으로 바꾸었으며
▶ String타입을 char 배열 타입으로 바꾸고
▶ for문을 돌려면 3, 6, 9가 포함된 경우에만 cnt를 +1씩 증가하게 만들어서
▶ 3, 6, 9의 갯수를 카운팅하였다.
다른 사람의 풀이
import java.util.Arrays;
class Solution {
public int solution(int order) {
return (int) Arrays.stream(String.valueOf(order).split("")).map(Integer::parseInt).filter(i -> i == 3 || i == 6 || i == 9).count();
}
}
▶ String.valueOf() 함수를 써서 정수타입의 order를 String타입으로 바꾼다.
▶ String타입으로 바뀐 상태에서 split() 메서드를 이용하여 "String배열"로 바뀌준다.
▶ stream(String.valueOf(order).split(""))
▶ 위 식에 따라 stream으로 감싸게 되면 반환타입이 Stream<String> 타입이 된다.
▶ 추가적으로 map(Integer::parseInt)를 사용하면 반환타입이 Stream<Integer>타입이 된다.
▶ filter() 메서드를 사용하면, Stream<Integer> 타입으로 원하는 값만 담을 수 있다.
▶ count()함수는 filter()메서드에 추출된 객체의 갯수를 세서 long타입으로 숫자를 반환한다.
▶ count() 리턴타입이 long이기 때문에 int(캐스팅연산자)를 써서 형변환을 해준다.
'프로그래머스(자바) > LV.0(자바)' 카테고리의 다른 글
합성수 찾기 → 이중 stream★ filter()를 두 번 사용할 필요x (0) | 2022.11.25 |
---|---|
외계행성의 나이 →Stream끝판왕★ (0) | 2022.11.25 |
피자 나뉘 먹기(2) ★최소공배수, 최대공약수★ (0) | 2022.11.25 |
숫자 찾기→문자열+숫자=문자열 (0) | 2022.11.25 |
암호 해독- substring(), toCharArray(), char->String에 대입가능, step (0) | 2022.11.24 |