JAVA/JAVA Algorithm 33

[백준] 1085 직사각형에서 탈출

문제 한수는 지금 (x, y)에 있다. 직사각형은 각 변이 좌표축에 평행하고, 왼쪽 아래 꼭짓점은 (0, 0), 오른쪽 위 꼭짓점은 (w, h)에 있다. 직사각형의 경계선까지 가는 거리의 최솟값을 구하는 프로그램을 작성하시오. 입력 첫째 줄에 x, y, w, h가 주어진다. 출력 첫째 줄에 문제의 정답을 출력한다. 제한 1 ≤ w, h ≤ 1,000 1 ≤ x ≤ w-1 1 ≤ y ≤ h-1 x, y, w, h는 정수 (구상) 좌표축을 생각했을때 다음과 같은 형태로 좌표가 존재한다고 생각하자. 그러면 최단거리는 점(x,y)가 x축가 만나는 거리 , y축과 만나는거리, 직사각형의 나머지 가로 또는 세로와 만나는 거리를 고려해 주면 된다. 이들 네가지를 구하여 최솟값을 출력해 주면 된다. 1.x축과의 거리 ..

JAVA/JAVA Algorithm 2022.08.21

[백준]10815번 숫자카드

문제 숫자 카드는 정수 하나가 적혀져 있는 카드이다. 상근이는 숫자 카드 N개를 가지고 있다. 정수 M개가 주어졌을 때, 이 수가 적혀있는 숫자 카드를 상근이가 가지고 있는지 아닌지를 구하는 프로그램을 작성하시오. 입력 첫째 줄에 상근이가 가지고 있는 숫자 카드의 개수 N(1 ≤ N ≤ 500,000)이 주어진다. 둘째 줄에는 숫자 카드에 적혀있는 정수가 주어진다. 숫자 카드에 적혀있는 수는 -10,000,000보다 크거나 같고, 10,000,000보다 작거나 같다. 두 숫자 카드에 같은 수가 적혀있는 경우는 없다. 셋째 줄에는 M(1 ≤ M ≤ 500,000)이 주어진다. 넷째 줄에는 상근이가 가지고 있는 숫자 카드인지 아닌지를 구해야 할 M개의 정수가 주어지며, 이 수는 공백으로 구분되어져 있다. 이..

JAVA/JAVA Algorithm 2022.08.21

[백준] 2750번 수 정렬하기

문제 N개의 수가 주어졌을 때, 이를 오름차순으로 정렬하는 프로그램을 작성하시오. 입력 첫째 줄에 수의 개수 N(1 ≤ N ≤ 1,000)이 주어진다. 둘째 줄부터 N개의 줄에는 수 주어진다. 이 수는 절댓값이 1,000보다 작거나 같은 정수이다. 수는 중복되지 않는다. 출력 첫째 줄부터 N개의 줄에 오름차순으로 정렬한 결과를 한 줄에 하나씩 출력한다. 사용한 문법 배열의 오름차순 내림차순 하는 방법 Arrays.sort(arr); // 배열을 오름 차순 정렬함 Arrarys.sort(arr,Comparator.reverseOrder()) ; //내림차순 정렬 이다. package codingTest; import java.io.BufferedReader; import java.io.InputStream..

JAVA/JAVA Algorithm 2022.08.21

[백준] 2798번 블랙잭 - 자바

문제 카지노에서 제일 인기 있는 게임 블랙잭의 규칙은 상당히 쉽다. 카드의 합이 21을 넘지 않는 한도 내에서, 카드의 합을 최대한 크게 만드는 게임이다. 블랙잭은 카지노마다 다양한 규정이 있다. 한국 최고의 블랙잭 고수 김정인은 새로운 블랙잭 규칙을 만들어 상근, 창영이와 게임하려고 한다. 김정인 버전의 블랙잭에서 각 카드에는 양의 정수가 쓰여 있다. 그 다음, 딜러는 N장의 카드를 모두 숫자가 보이도록 바닥에 놓는다. 그런 후에 딜러는 숫자 M을 크게 외친다. 이제 플레이어는 제한된 시간 안에 N장의 카드 중에서 3장의 카드를 골라야 한다. 블랙잭 변형 게임이기 때문에, 플레이어가 고른 카드의 합은 M을 넘지 않으면서 M과 최대한 가깝게 만들어야 한다. N장의 카드에 써져 있는 숫자가 주어졌을 때, ..

JAVA/JAVA Algorithm 2022.08.21

[백준] 14425번 문자열 집합

문제 총 N개의 문자열로 이루어진 집합 S가 주어진다. 입력으로 주어지는 M개의 문자열 중에서 집합 S에 포함되어 있는 것이 총 몇 개인지 구하는 프로그램을 작성하시오. 입력 첫째 줄에 문자열의 개수 N과 M (1 ≤ N ≤ 10,000, 1 ≤ M ≤ 10,000)이 주어진다. 다음 N개의 줄에는 집합 S에 포함되어 있는 문자열들이 주어진다. 다음 M개의 줄에는 검사해야 하는 문자열들이 주어진다. 입력으로 주어지는 문자열은 알파벳 소문자로만 이루어져 있으며, 길이는 500을 넘지 않는다. 집합 S에 같은 문자열이 여러 번 주어지는 경우는 없다. 출력 첫째 줄에 M개의 문자열 중에 총 몇 개가 집합 S에 포함되어 있는지 출력한다. 나의 답안 package codingTest; import java.io...

JAVA/JAVA Algorithm 2022.08.18

[백준] 11653번 소인수분해

문제 정수 N이 주어졌을 때, 소인수분해하는 프로그램을 작성하시오. 입력 첫째 줄에 정수 N (1 ≤ N ≤ 10,000,000)이 주어진다. 출력 N의 소인수분해 결과를 한 줄에 하나씩 오름차순으로 출력한다. N이 1인 경우 아무것도 출력하지 않는다. package codingTest; import java.util.Scanner; public class Algorithm4 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int num = sc.nextInt(); double sqNum = Math.sqrt(num); int k = 2; while (k

JAVA/JAVA Algorithm 2022.08.17

[백준]10872번 팩토리얼 (꼬리 재귀 이용함)

문제 0보다 크거나 같은 정수 N이 주어진다. 이때, N!을 출력하는 프로그램을 작성하시오. 입력 첫째 줄에 정수 N(0 ≤ N ≤ 12)이 주어진다. 출력 첫째 줄에 N!을 출력한다. 알고리즘 분류 수학 , 구현, 조합론 처음 구현한 코드는 다음과 같다. // 백준 10872번 // n! 출력하기 . package codingTest; import java.util.Scanner; public class Algorithm3 { static int factorial(int n) { if (n (2,3) >>(1,6) >> 어? 1 이네 total을 return하자 라고 해서 6 을 리턴한다.

JAVA/JAVA Algorithm 2022.08.17

최대공약수와 최소공배수 구하는 알고리즘 만들기

두수 a,b 와 a를 b로 나눈 나머지를 r이라고 하자. a와 b의 최대공약수는 b와 r의 최대 공약수와 같음을 이용하자. 방법 1. 재귀함수를 사용하는 방법 static int GCD(int a, int b){ // 최대공약수 if (a%b == 0) { return b; } return GCD(b, a % b); } package Algorithm; import java.util.Scanner; public class Gcd { static int a, b; public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("두 수를 입력하시오.!"); a = sc.nextInt(); b = s..

JAVA/JAVA Algorithm 2022.08.14

[백준]1712 손익분기점을 구하는 알고리즘 구현하기

[문제] 월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 재료비와 인건비 등 총 B만원의 가변 비용이 든다고 한다. 예를 들어 A=1,000, B=70이라고 하자. 이 경우 노트북을 한 대 생산하는 데는 총 1,070만원이 들며, 열 대 생산하는 데는 총 1,700만원이 든다. 노트북 가격이 C만원으로 책정되었다고 한다. 일반적으로 생산 대수를 늘려 가다 보면 어느 순간 총 수입(판매비용)이 총 비용(=고정비용+가변비용)보다 많아지게 된다. 최초로 총 수입이 총 비용보다 많아져 이익이 발생하는 지점을 손익분기점(BREAK-EVEN POINT)이라고 한다. A, B, C가 주..

JAVA/JAVA Algorithm 2022.08.08