일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- scope function
- Android Interceptor
- 습관만들기
- Android WebView
- Android Navigation
- android recyclerview
- Android
- 안드로이드
- Android ViewPager2
- WebView
- 알고리즘 자바
- MVP Architecture
- 프로그래머스 알고리즘
- 안드로이드 카카오 로그인
- Kotlin FCM
- Java
- Android 12
- Android ProgressBar
- Android Jetpack
- 영어공부
- 영어독립365
- Android 12 대응
- 카카오 알고리즘
- DataBinding
- Kotlin
- 안드로이드 fcm
- 66챌린지
- 안드로이드 갤러리 접근
- OkHttp Interceptor
- Android DataBinding
Archives
- Today
- Total
Developer Geek
프로그래머스 소수 찾기 Java 본문
반응형
소수 찾기
문제 설명
한자리 숫자가 적힌 종이 조각이 흩어져있습니다. 흩어진 종이 조각을 붙여 소수를 몇 개 만들 수 있는지 알아내려 합니다.
각 종이 조각에 적힌 숫자가 적힌 문자열 numbers가 주어졌을 때, 종이 조각으로 만들 수 있는 소수가 몇 개인지 return 하도록 solution 함수를 완성해주세요.
제한사항
- numbers는 길이 1 이상 7 이하인 문자열입니다.
- numbers는 0~9까지 숫자만으로 이루어져 있습니다.
- "013"은 0, 1, 3 숫자가 적힌 종이 조각이 흩어져있다는 의미입니다.
입출력 예
numbers | return |
---|---|
"17" | 3 |
"011" | 2 |
입출력 예 설명
예제 #1
[1, 7]으로는 소수 [7, 17, 71]를 만들 수 있습니다.
예제 #2
[0, 1, 1]으로는 소수 [11, 101]를 만들 수 있습니다.
- 11과 011은 같은 숫자로 취급합니다.
학습한 풀이
Code
import java.util.HashSet;
class Solution {
public int solution(String numbers) {
HashSet<Integer> set = new HashSet<>();
permutation("", numbers, set);
int count = 0;
while(set.iterator().hasNext()){
int a = set.iterator().next();
set.remove(a);
if(a==2) count++;
if(a%2!=0 && isPrime(a)){
count++;
}
}
return count;
}
public boolean isPrime(int n){
if(n==0 || n==1) return false;
for(int i=3; i<=(int)Math.sqrt(n); i+=2){
if(n%i==0) return false;
}
return true;
}
public void permutation(String prefix, String str, HashSet<Integer> set) {
int n = str.length();
//if (n == 0) System.out.println(prefix);
if(!prefix.equals("")) set.add(Integer.valueOf(prefix));
for (int i = 0; i < n; i++)
permutation(prefix + str.charAt(i), str.substring(0, i) + str.substring(i+1, n), set);
}
}
완전탐색 예제
Code
public static void main(String[] args) {
String numbers = "170";
Set<Integer> set = new HashSet<>();
recursiveCompletSearch("", numbers, set);
for (Integer num: set) {
System.out.println(num);
}
}
public static void recursiveCompletSearch(String prefix, String str, Set<Integer> set) {
if (str.length() == 0)
return;
int len = str.length();
for (int i = 0; i < len; i++) {
String tempPrefix = prefix + str.charAt(i);
set.add(Integer.parseInt(tempPrefix));
String restString = str.substring(0, i) + str.substring(i + 1, len);
recursiveCompletSearch(tempPrefix, restString, set);
}
}
Result
0
1
17
710
70
7
71
170
10
107
701
recursiveCompleteSearch 설명
반응형
'Java > 알고리즘' 카테고리의 다른 글
숫자 문자열과 영단어 Java (0) | 2022.07.25 |
---|---|
프로그래머스 타겟넘버 Java (0) | 2022.05.12 |
프로그래머스 다트 게임 Java (0) | 2022.05.04 |
프로그래머스 1차 비밀지도 Java (0) | 2022.05.03 |
프로그래머스 짝지어 제거하기 Java (0) | 2022.04.29 |
Comments