Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 스프링부트 도커 배포
- 문자열
- 스택
- Stack
- 프로그래머스 문자열 정렬
- 스프링부트 도커로 배포
- 큐
- Queue
- Lv1
- StringTokenizer
- 백준
- 백준 N과 M 자바
- 삼각형의 완성조건
- SWEA
- index of
- java
- lv0
- 버퍼
- 프로그래머스
- 스프링부트 도커
- COS Pro
- 이진수 변환
- 프로그래머스 풀이
- Programmers
- 클라이언트
- 알고리즘
- 프로그래머스 자바
- 오름차순 정렬
- lv2
- 자바
Archives
- Today
- Total
mun dev
[Programmers] 나누어 떨어지는 수 자바 본문
문제설명
array의 각 element 중 divisor로 나누어 떨어지는 값을 오름차순으로 정렬한 배열을 반환하는 함수, solution을 작성해주세요. divisor로 나누어 떨어지는 element가 하나도 없다면 배열에 -1을 담아 반환하세요.
제한 사항
- arr은 자연수를 담은 배열입니다.
- 정수 i, j에 대해 i ≠ j 이면 arr[i] ≠ arr[j] 입니다.
- divisor는 자연수입니다.
- array는 길이 1 이상인 배열입니다.
입출력 예
arr | divisor | return |
[5, 9, 7, 10] | 5 | [5, 10] |
[2, 36, 1, 3] | 1 | [1, 2, 3, 36] |
[3,2,6] | 10 | [-1] |
통과한 코드 ✅
import java.util.Arrays;
class Solution {
public int[] solution(int[] arr, int divisor) {
int index=0;
int count=0;
for(int i=0; i<arr.length; i++){
if(arr[i]%divisor==0){
count++;
}
else if(i==arr.length-1 && count==0){
count=1;
}
}
int[] answer=new int[count];
for(int i=0; i<=arr.length-1; i++){
if(arr[i]%divisor==0){
answer[index]=arr[i];
index++;
}if(count==1&&index==0){
answer[index]=-1;
}
}
Arrays.sort(answer);
return answer;
}
}
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[Programmers] 포켓몬 자바 (0) | 2023.03.02 |
---|---|
[Programmers] 핸드폰 번호 가리기 자바 (0) | 2023.03.02 |
[Programmers] 콜라츠 추측 자바 (0) | 2023.02.28 |
[Programmers] 두 정수 사이의 합 자바 (0) | 2023.02.27 |
[Programmers] 하샤드 수 자바 (0) | 2023.02.27 |