Q1. 두 정수 A와 B가 주어졌을 때, A와 B를 비교하는 프로그램을 작성하시오.
입력 : 첫째 줄에 A와 B가 주어진다. A와 B는 공백 한 칸으로 구분되어져 있다.
출력 : 첫째 줄에 다음 세 가지 중 하나를 출력한다.
✔️ A가 B보다 큰 경우에는 '>'를 출력한다.
✔️ A가 B보다 작은 경우에는 '<'를 출력한다.
✔️ A와 B가 같은 경우에는 '=='를 출력한다.
✅ 백준 1330번 바로가기
import java.util.*;
public class Main {
public static void main(String args[]){
Scanner sc = new Scanner(System.in);
int a = sc.nextInt();
int b = sc.nextInt();
if (a>b){
System.out.println(">");
}
else if(a<b){
System.out.println("<");
}
else if(a==b){
System.out.println("==");
}
}
}
Q2. 시험 점수를 입력받아 90 ~ 100점은 A, 80 ~ 89점은 B, 70 ~ 79점은 C, 60 ~ 69점은 D, 나머지 점수는 F를 출력하는 프로그램을 작성하시오.
입력 : 첫째 줄에 시험 점수가 주어진다. 시험 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.
출력 : 시험 성적을 출력한다.
✅ 백준 9498번 바로가기
import java.util.*;
public class Main {
public static void main(String args[]){
Scanner sc = new Scanner(System.in);
int a = sc.nextInt();
if(a>=90 && a<=100){
System.out.println("A");
}
else if (a>=80 && a<=89){
System.out.println("B");
}
else if(a>=70 && a<=79){
System.out.println("C");
}
else if(a>=60 && a<=69){
System.out.println("D");
}
else {
System.out.println("F");
}
}
}
Q3. 연도가 주어졌을 때, 윤년이면 1, 아니면 0을 출력하는 프로그램을 작성하시오. 윤년은 연도가 4의 배수이면서, 100의 배수가 아닐 때 또는 400의 배수일 때이다. 예를 들어, 2012년은 4의 배수이면서 100의 배수가 아니라서 윤년이다. 1900년은 100의 배수이고 400의 배수는 아니기 때문에 윤년이 아니다. 하지만, 2000년은 400의 배수이기 때문에 윤년이다.
입력 : 첫째 줄에 연도가 주어진다. 연도는 1보다 크거나 같고, 4000보다 작거나 같은 자연수이다.
출력 : 첫째 줄에 윤년이면 1, 아니면 0을 출력한다.
✅ 백준 2753번 바로가기
import java.util.*;
public class Main {
public static void main(String args[]){
Scanner sc = new Scanner(System.in);
int year = sc.nextInt();
if(year%4==0 && year%100!=0 || year%400==0){
System.out.println("1");
}
else{
System.out.println("0");
}
}
}
문제에서 제시한 조건을 보면 4의 배수이면서 100의 배수가 아닐 때 또는 400의 배수일 때라고 나와있다.
조건을 나누어서 살펴보면
1. 4의 배수이면서 100의 배수가 아닐 때 (AND &&)
2. 400의 배수일 때 (OR ||)
연산자의 우선순위와 연산 방향을 생각하여 조건문을 작성하면 된다.
Q4. 흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 1부터 4까지 번호를 갖는다.
"Quadrant n"은 "제 n사분면"이라는 뜻이다.예를 들어, 좌표가 (12, 5)인 점 A는 x좌표와 y좌표가 모두 양수이므로 제1사분면에 속한다. 점 B는 x좌표는 음수이고 y좌표가 양수이므로 제2사분면에 속한다. 점의 좌표를 입력받아 그 점이 어느 사분면에 속하는지 알아내는 프로그램을 작성하시오. 단, x좌표와 y좌표는 모두 양수나 음수라고 가정한다.
입력 : 첫 줄에는 정수 x가 주어진다. 다음 줄에는 정수 y가 주어진다.
출력 : 점 (x, y)의 사분면 번호(1, 2, 3, 4 중 하나)를 출력한다.
✅ 백준 14681번 바로가기
import java.util.*;
public class Main {
public static void main(String args[]){
Scanner sc = new Scanner(System.in);
int x = sc.nextInt();
int y = sc.nextInt();
if(x>0 && y>0){
System.out.println("1");
}
else if (x<0 && y>0){
System.out.println("2");
}
else if (x<0 && y<0){
System.out.println("3");
}
else{
System.out.println("4");
}
}
}
1사분면은 x,y 둘 다 양수이다. 하나라도 음수라면 1사분면이 아니다. x,y가 둘 다 양수이어야 true이므로 &&연산자를 이용하여 조건식을 설계하면 된다. 2,3,4분면도 마찬가지로 설계하면 된다.
Q5. 상근이는 매일 아침 알람을 듣고 일어난다. 알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다. 상근이는 모든 방법을 동원해보았지만, 조금만 더 자려는 마음은 그 어떤 것도 없앨 수가 없었다. 이런 상근이를 불쌍하게 보던 창영이는 자신이 사용하는 방법을 추천해 주었다. 바로 "45분 일찍 알람 설정하기"이다. 이 방법은 단순하다. 원래 설정되어 있는 알람을 45분 앞서는 시간으로 바꾸는 것이다. 어차피 알람 소리를 들으면, 알람을 끄고 조금 더 잘것이기 때문이다. 이 방법을 사용하면, 매일 아침 더 잤다는 기분을 느낄 수 있고, 학교도 지각하지 않게 된다. 현재 상근이가 설정한 알람 시각이 주어졌을 때, 창영이의 방법을 사용한다면, 이를 언제로 고쳐야 하는지 구하는 프로그램을 작성하시오.
입력 : 첫째 줄에 두 정수 H와 M이 주어진다. 그리고 이것은 현재 상근이가 설정해 놓은 알람 시간 H시 M분을 의미한다. 입력 시간은 24시간 표현을 사용한다. 24시간 표현에서 하루의 시작은 0:0(자정)이고, 끝은 23:59(다음날 자정 1분 전)이다. 시간을 나타낼 때, 불필요한 0은 사용하지 않는다.
출력 : 첫째 줄에 상근이가 창영이의 방법을 사용할 때, 설정해야 하는 알람 시간을 출력한다. (입력과 같은 형태로 출력하면 된다.)
✅ 백준 2884번 바로가기
import java.util.*;
public class Main {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int H = sc.nextInt();
int M = sc.nextInt();
if (M < 45) {
H--;
M = 60 - (45-M);
if(H<0){
H = 23;
}
System.out.println(H + " " + M);
}
else{
System.out.println(H + " " + (M-45));
}
}
}
첫번째 알고리즘은 입력받은 분(M)가 45 미만이면 시(H)를 -1 해주고, 아닐 경우 입력받은 분(M)에 -45를 해주면 된다. 또 시(H)가 0보다 작아질 경우 시(H)를 23으로 수정해준다. 첫번째 if문에서 M = 60 - (m-45)가 아니라 (45-m)을 해주는 이유는 음수 값이 나올 수 있으므로 절대값을 구하기 위함이다.
import java.util.*;
public class Main {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int h = sc.nextInt();
int m = sc.nextInt();
if (m < 45) {
h--;
m = 60 - Math.abs(m-45); // Math.abs() : 절대값 변환 메소드
if(h<0){
h = 23;
}
System.out.println(h + " " + m);
}
else{
System.out.println(h + " " + (m-45));
}
}
}
m 값을 절대값 변환 메소드를 사용한 것 일뿐 위와 동일한 알고리즘이다.
import java.util.*;
public class Main {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int H = sc.nextInt();
int M = sc.nextInt();
if(M<45){
M += 15;
if(H==0){
H = 23;
System.out.println(H + " " + M);
}
else{
H--;
System.out.println(H + " " + M);
}
}
else{
M -= 45;
System.out.println(H + " " + M);
}
}
}
두번째 알고리즘은 분(M)이 45 미만이면 시간(H)에서 1을 빼고 분(M)에 15를 더해주고, 시간이(0)일때도 고려하여 조건문을 설계했다. 그리고 분(M)이 45 이상이면 분(M)에서 45를 빼준다.
Q6. KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다. 또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다. 훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
입력 : 첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A와 분 B가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C가 분 단위로 주어진다.
출력 : 첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)
✅ 백준 2525번 바로가기
import java.util.*;
public class Main {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int A = sc.nextInt();
int B = sc.nextInt();
int C = sc.nextInt();
int min = A * 60 + B + C;
int hour = (min / 60) % 24;
int min2 = min % 60;
System.out.println(hour + " " + min2);
}
}
첫번째 알고리즘은 주어진 모든 시간을 분으로 변환하고 합을 구한 후 오븐구이가 끝나는 시각을 계산하는 알고리즘이다. 변수 min에 입력한 모든 시간을 분으로 변환한 다음 합을 구한 수를 저장한다. A * 60인 이유는 A는 시간이기 때문이다. (1시간 = 60분) 예를 들어 min이 1100이라고 하면 오븐구이가 끝나는 '시'는 1100/60이고 18'시'가 될 것이다. 오븐구이가 끝나는 '분'은 60으로 나눈 값의 나머지이므로 1100%60 = 20, 우리가 구하고자 하는 오븐구이가 끝나는 시각은 18시 20분이 되는 것이다. 그리고 문제를 보면 디지털 시계는 23시 59에서 1분이 지나면 0시 0분이 된다고 했으므로 24 이상이면 어떻게 해야할지 생각해야한다. 24 이상이면 다시 0부터 시작하도록 24를 나눈 나머지 연산을 하면 된다.
import java.util.*;
public class Main {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int A = sc.nextInt();
int B = sc.nextInt();
int C = sc.nextInt();
int min = A * 60 + B + C;
int hour = min/60;
int min2 = min%60;
if(hour >= 24){
hour -= 24;
}
System.out.println(hour + " " + min2);
}
}
똑같은 알고리즘이지만 설계 방법이 다르다. 위의 풀이에서는 24 이상이면 다시 0부터 시작하도록 24를 나눈 나머지 연산을 했지만 이 풀이에서는 조건문을 이용하여 '시'가 24이상일때 '시'에서 24를 빼줬다.
Q7. 1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 가은 규칙에 따라 상금을 받는 게임이 있다.
1. 같은 눈이 3개가 나오면 10,000원+(같은 눈)*1,000원의 상금을 받게 된다.
2. 같은 눈이 2개가 나오는 경우에는 1,000원+(같은 눈)*100원의 상금을 받게 된다.
3. 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)*100원의 상금을 받게 된다.
예를 들어, 3개의 눈 3,3,6이 주어지면 상금은 1,000+3*100으로 계산되어, 1,300원을 받게 된다. 또 3개의 눈이 2,2,2로 주어지면 10,000+2*1,000으로 계산되어, 12,000원을 받게 된다. 3개의 눈이 6,2,5로 주어지면 그중 가장 큰 값이 6이므로 6*100으로 계산되어 600원을 상금으로 받게 된다.
입력 : 첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력 : 첫째 줄에 게임의 상금을 출력 한다.
✅ 백준 2480번 바로가기
import java.util.*;
public class Main {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int D1 = sc.nextInt();
int D2 = sc.nextInt();
int D3 = sc.nextInt();
int m = 0;
if(D1==D2 && D1==D3 && D2==D3){
m = 10000 + D1 * 1000;
}
else if(D1==D2 || D1==D3){
m = 1000 + D1 * 100;
}
else if (D2==D3){
m = 1000 + D2 * 100;
}
else {
int a = D1 > D2 ? D1 : D2;
int b = a > D3 ? a : D3;
m = b*100;
}
System.out.println(m);
}
}
문제에서 제시한 조건은 주사위 3개의 눈이 전부 같거나, 2개만 같거나, 전부 틀리거나 총 3개이다. 첫번째 조건문은 전부 같아야 하므로 &&연산을 이용하여 설계했다. 두번째 조건문은 2개만 같아야 하므로 ||연산을 이용하여 설계했다. 첫번째 조건문과 다르게 두개의 조건문으로 나누어서 설계했는데, 첫번째 조건문은 전부 같으므로 아무 주사위 눈을 가져와도 상관 없지만 두번째 조건문은 2개만 같으므로 눈의 수가 다른 나머지 한개의 주사위 숫자를 가져오면 안된다. D1==D2, D1==D3일 경우와 D2==D3일 경우로 나누어서 설계했다. 마지막으로 주사위의 눈이 전부 다른 경우인데 문제에서 주사위의 눈이 모두 다를 경우 그 중 가장 큰 눈 * 100의 상금을 받게 된다고 했다. 가장 큰 눈을 구하는 방법은 삼항 연산자를 이용해서 설계했다. 변수 a에 D1이 D2보다 크면 D1을 저장하고 D1이 D2보다 작으면 D2를 저장한다. 변수 b는 D1과 D2를 비교하여 더 큰 값과 D3를 비교하여 가장 큰 값을 저장한다.
'백준 문제풀이 > 단계별 문제 풀이 (Basic-Java)' 카테고리의 다른 글
05. 문자열 (0) | 2023.03.06 |
---|---|
04. 1차원 배열 (0) | 2023.03.01 |
03. 반복문 (0) | 2023.02.25 |
01. 입출력과 사칙연산 (0) | 2023.02.13 |