1929번: 소수 구하기 첫째 줄에 자연수 M과 N이 빈 칸을 사이에 두고 주어진다. (1 ≤ M ≤ N ≤ 1,000,000) M이상 N이하의 소수가 하나 이상 있는 입력만 주어진다. www.acmicpc.net 문제 M이상 M이하의 소수를 모두 출력하시오. 풀이 에라토스테네스의 체를 이용하여 소수를 구했습니다.’ 에라토스테네스의 체 for(int i=2; i= N) break; if(!A[now]) A[now] = true; } } 에라토스테네스의 체는 2~ $\sqrt{N}$까지의 모든 곱을 구하여 구해진다면 해당 숫자를 날려 구간의 소수를 모두 구할 수 있습니다. 출력 StringBuilder sb = new StringBuilder(); for(int i= M > 1 ? M : 2 ; i 1 ?..
전체 글
창의의 개발블로그입니다.문제 회의실의 사용시간 (start, end)가 주어졌을 때 최대한 회의를 많이할 수 있는 횟수를 구하여라 풀이 회의가 종료되는 시간이 짧은 회의를 우선으로 두고 구하였다. 정렬 Arrays.sort(A, new Comparator() { @Override public int compare(int[] o1, int[] o2) { if(o1[1] == o2[1]) return o1[0] - o2[0]; else return o1[1] - o2[1]; } }); 종료시간이 짧은 순서대로 정렬하였다. 종료시간이 같은 경우 시작시간이 짧은 순으로 정렬했다. 종료시간이 같을 경우에 해당 회의가 먼저 선택되면 시작시간이 짧은 회의를 선택하지 못하게 된다. 비교 int answer = 0; int now = 0; f..
1541번: 잃어버린 괄호 첫째 줄에 식이 주어진다. 식은 ‘0’~‘9’, ‘+’, 그리고 ‘-’만으로 이루어져 있고, 가장 처음과 마지막 문자는 숫자이다. 그리고 연속해서 두 개 이상의 연산자가 나타나지 않고, 5자리보다 www.acmicpc.net 문제 수식이 주어졌을 때 괄호를 삽입해 식의 최솟값을 구하여라. 풀이 “-”를 기준으로 자르고 합을 모두 계산한 다음 뺄셈연산을 진행해주는 것이 가장 작은 값이라고 생각했다. “-”를 기준으로 문자열을 자른다. “+”를 기준으로 문자열을 잘라 모든 값을 더해준다. 더한값들을 모두 빼준다. 값 입력 BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringTokenizer ..
11047번: 동전 0 첫째 줄에 N과 K가 주어진다. (1 ≤ N ≤ 10, 1 ≤ K ≤ 100,000,000) 둘째 줄부터 N개의 줄에 동전의 가치 Ai가 오름차순으로 주어진다. (1 ≤ Ai ≤ 1,000,000, A1 = 1, i ≥ 2인 경우에 Ai는 Ai-1의 배수) www.acmicpc.net 문제 동전의 종류가 주어졌을 때 주어진 금액을 만들 수 있는 동전 개수의 최솟값을 구하여라. 풀이 다음의 순서로 최솟값을 구한다. 오름차순 정렬되어있기 때문에 N-1부터 값을 낮추면서 주어진 금액과 같거나 작은 동전을 탐색한다. 만약 동전을 찾았다면 주어진 금액/동전금액을 계산하면 동전의 개수를 구할 수 있다. 그리고 주어진 금액을 나머지로 갱신한다. 이 반복을 주어진 금액이 0원이 될 때 까지 반복..
1715번: 카드 정렬하기 정렬된 두 묶음의 숫자 카드가 있다고 하자. 각 묶음의 카드의 수를 A, B라 하면 보통 두 묶음을 합쳐서 하나로 만드는 데에는 A+B 번의 비교를 해야 한다. 이를테면, 20장의 숫자 카드 묶음과 30장 www.acmicpc.net 문제 카드 묶음 2개가 주어졌을 때 이 두개의 묶음을 합쳐 정렬하기 위해서는 카드의 갯수를 더한 만큼 비교를해야 한다. 이 때 작은 묶음들부터 더해나가면서 비교하면 최소값이 된다. 카드 묶음들이 주어졌을 때 비교횟수가 가장 작은 최솟값을 구하시오. 풀이 우선순위 큐를 사용하여 큐에 들어오는 값들을 최솟값 순서대로 사용할 수 있도록 정렬해준다. 큐에서 값을 2개씩 꺼내어 값을 합하고 이 값을 큐에 다시 넣는다. 이 값의 합은 answer 더한다. 큐..
1744번: 수 묶기 길이가 N인 수열이 주어졌을 때, 그 수열의 합을 구하려고 한다. 하지만, 그냥 그 수열의 합을 모두 더해서 구하는 것이 아니라, 수열의 두 수를 묶으려고 한다. 어떤 수를 묶으려고 할 때, 위치에 www.acmicpc.net 문제 수를 묶거나(두 수의 곱) 묶지않고 주어진 수열의 합의 최댓값을 구하여라. 풀이 3가지의 경우의 수로 나눠서 최선이 무엇인지 생각해보고 풀었습니다. 양수의 경우는 큰 값끼리 묶는 것(곱하는 것)이 가장 최선 음수의 경우는 가장 작은 값끼리 묶는 것(곱하는 것)이 가장 최선 음수 중에서 남는 값이 있다면 묶는 것(곱하는 것)이 가장 최선 양수의 경우 while (positive.size() > 1 ){ int x = positive.poll(); int y..
개요 프로젝트에 대한 테스트를 작성하던 중 List로 반환되는 DTO에 대한 검증에 대한 코드가 길어져 해결할 방법이 있을까 찾아보았다. 기존에 mockMvc.perform()의 체이닝 메소드인 .andExpect를 사용해서 json의 값을 하나하나 비교해주었다. 검증할 DTO가 많아질 경우 다음과 같이 코드가 너무 길어졌다. @Test @DisplayName("read all post test") public void readAllPostTest() throws Exception { PostDTO after1 = PostDTO.entityToDTO(PostEntity.initEntity(post1, UserEntity.builder().email(post1.getEmail()).build())); af..
개요 개발하면서 profile을 통해 로컬과 배포 환경에서의 설정을 분리했지만 빌드를 할때마다 프로파일을 변경해줘야하는 것이 불편해서 찾아보게 되었습니다. 찾다보니 .jar를 실행할 때 환경변수로 사용할 프로파일을 결정할 수 있었고 docker를 사용하여 배포를 하고 있었기 때문에 docker의 환경변수로도 사용할 수 있는지 찾아보았고 방법을 정리했습니다. application.yml 설정 # default spring: profiles: active: prod group: "prod" : "prod" "dev" : "dev" jpa: hibernate: ddl-auto: update show-sql: true springboot: jwt: secret: asdlkqwjie120938 server: ss..