Carnival7
Change Developer
Carnival7
전체 방문자
오늘
어제
  • 분류 전체보기
    • 자바의 정석
    • 프로그래밍 언어별 tools
      • 파이썬
      • 자바
    • 코딩 테스트
      • 백준 강의 기초편
      • 백준 강의 연습편
      • 백준 강의 문제편
      • 삼성 기출
      • 백준 - 일반
      • 카카오 기출
      • 프로그래머스 - 일반
      • 코테 풀이 Tools
    • CS
      • Network
      • 운영체제
      • 알고리즘
      • DB
    • Web_Backend
      • Spring
      • 스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술
      • 스프링 핵심 원리 - 기본편
    • DevOps
    • IT 업무 지식
      • 인프라
      • 클라우드
    • 자격증
      • AWS - CLF
      • 정처기 - 실기
    • 생각 정리

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • DMZ
  • Github Actions
  • 알고리즘 #백준강의기초편 #코딩테스트
  • 프로그래머스 #카카오기출 #레벨2
  • ci/cd
  • 스프링 부트 무중단 웹 서비스
  • DevOps
  • 삼성기출 #2023 #상반기
  • 슬라이딩 윈도우 #덱
  • nginx
  • 코딩테스트 #삼성기출 #구현 #시뮬레이션
  • 스프링 #AOP
  • code deploy
  • 슬라이딩 윈도우
  • 스프링 #인터셉터 #AOP #필터
  • 삼성기출 #백준강의문제편

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7

Change Developer

코딩 테스트/프로그래머스 - 일반

level 2.소수 찾기

2021. 10. 23. 13:27

https://programmers.co.kr/learn/courses/30/lessons/42839

 

코딩테스트 연습 - 소수 찾기

한자리 숫자가 적힌 종이 조각이 흩어져있습니다. 흩어진 종이 조각을 붙여 소수를 몇 개 만들 수 있는지 알아내려 합니다. 각 종이 조각에 적힌 숫자가 적힌 문자열 numbers가 주어졌을 때, 종이

programmers.co.kr

package programmers.level02.findPrimeNum;

import java.util.*;

public class FindPrimeNum_carnival77 {

    static int answer = 0 ;
    static boolean[] used = new boolean[7];
    static ArrayList<Integer> arr = new ArrayList<>();
    static String num;

    public void dfs(String[] str, int m,int idx){
        if(idx == m) {
            if (!arr.contains(Integer.parseInt(String.join("",str))))
                arr.add(Integer.parseInt(String.join("",str)));
            return;
        }

        for(int i=0;i<num.length();i++){
            if(used[i])
                continue;
            used[i]=true;
            str[idx] = Character.toString(num.charAt(i));
            dfs(str,m,idx+1);
            used[i]=false;
        }
    }

    public void prime(int x){
        if(x==0) return;
        if(x==1) return;

        for(int i=2;i<=Math.sqrt(x);i++){
            if(x%i==0) return;
        }

        answer+=1;
    }

    public int solution(String numbers) {
        num = numbers;
        // 1. 주어진 numbers의 순열의 모든 경우의 수를 조합
        for(int i=1;i<numbers.length()+1;i++){
            String[] str=new String[i];
            dfs(str,i,0);
        }
        // 2. 해당 숫자들 중 소수 판별
        for(int x:arr){
            prime(x);
        }
        return answer;
    }

    public static void main(String[] args) {
        String numbers = "17";
        FindPrimeNum_carnival77 sol = new FindPrimeNum_carnival77();
        System.out.println(sol.solution(numbers));
    }
}

'코딩 테스트 > 프로그래머스 - 일반' 카테고리의 다른 글

레벨2. 이중우선순위큐  (0) 2021.11.19
레벨2.교점에 별 만들기  (0) 2021.11.19
    '코딩 테스트/프로그래머스 - 일반' 카테고리의 다른 글
    • 레벨2. 이중우선순위큐
    • 레벨2.교점에 별 만들기
    Carnival7
    Carnival7

    티스토리툴바