drexqq
[Java, 자바] 백준알고리즘 단계별로 풀기 - 2단계 본문
1330번
두 정수 A와 B가 주어졌을 때, A와 B를 비교하는 프로그램을 작성하시오.
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String num = sc.nextLine();
// .next() -> 공백 제거
// /nextLine() -> 공백 유지
String splitArr[] = num.split(" ");
int n1, n2;
n1 = Integer.parseInt(splitArr[0]);
n2 = Integer.parseInt(splitArr[1]);
if (n1 == n2) {
System.out.println("==");
}
else if (n1 > n2) {
System.out.println(">");
}
else {
System.out.println("<");
}
}
}
9498번
시험 점수를 입력받아 90 ~ 100점은 A, 80 ~ 89점은 B, 70 ~ 79점은 C, 60 ~ 69점은 D, 나머지 점수는 F를 출력하는 프로그램을 작성하시오.
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) {
System.out.println("A");
}
else if (a >= 80) {
System.out.println("B");
}
else if (a >= 70) {
System.out.println("C");
}
else if (a >= 60) {
System.out.println("D");
}
else {
System.out.println("F");
}
}
}
2753번
연도가 주어졌을 때, 윤년이면 1, 아니면 0을 출력하는 프로그램을 작성하시오.
윤년은 연도가 4의 배수이면서, 100의 배수가 아닐 때 또는 400의 배수일 때이다.
예를 들어, 2012년은 4의 배수이면서 100의 배수가 아니라서 윤년이다. 1900년은 100의 배수이고 400의 배수는 아니기 때문에 윤년이 아니다. 하지만, 2000년은 400의 배수이기 때문에 윤년이다.
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int a = sc.nextInt();
// 4의 배수이면서, 100의 배수가 아닐 때 또는 400의 배수일 때
if ( (a % 4 == 0) && (a % 100 != 0 || a % 400 == 0) ) {
System.out.println("1");
}
else {
System.out.println("0");
}
}
}
14681번
흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 1부터 4까지 번호를 갖는다. "Quadrant n"은 "제n사분면"이라는 뜻이다
예를 들어, 좌표가 (12, 5)인 점 A는 x좌표와 y좌표가 모두 양수이므로 제1사분면에 속한다. 점 B는 x좌표가 음수이고 y좌표가 양수이므로 제2사분면에 속한다.
점의 좌표를 입력받아 그 점이 어느 사분면에 속하는지 알아내는 프로그램을 작성하시오. 단, x좌표와 y좌표는 모두 양수나 음수라고 가정한다.
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();
int Quadrant = 0;
if (x > 0 && y > 0) {
Quadrant = 1;
}
else if (x < 0 && y > 0) {
Quadrant = 2;
}
else if (x < 0 && y < 0) {
Quadrant = 3;
}
else if (x > 0 && y < 0) {
Quadrant = 4;
}
System.out.println(Quadrant);
}
}
2884번
상근이는 매일 아침 알람을 듣고 일어난다. 알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다.
상근이는 모든 방법을 동원해보았지만, 조금만 더 자려는 마음은 그 어떤 것도 없앨 수가 없었다.
이런 상근이를 불쌍하게 보던, 창영이는 자신이 사용하는 방법을 추천해 주었다.
바로 "45분 일찍 알람 설정하기"이다.
이 방법은 단순하다. 원래 설정되어 있는 알람을 45분 앞서는 시간으로 바꾸는 것이다. 어차피 알람 소리를 들으면, 알람을 끄고 조금 더 잘 것이기 때문이다. 이 방법을 사용하면, 매일 아침 더 잤다는 기분을 느낄 수 있고, 학교도 지각하지 않게 된다.
현재 상근이가 설정한 알람 시각이 주어졌을 때, 창영이의 방법을 사용한다면, 이를 언제로 고쳐야 하는지 구하는 프로그램을 작성하시오.
설명
받은 분에서 45분을 줄여야하니 M이 45보다 작게 된다면 시간도 한시간 줄어든다
때문에 M < 45 라는 조건에 H--를 걸어주고
이렇게 되면 예를 들어서 0시 0분이라고 가정을 한다면 H값이 -1이 되기때문에 H가 0보다 작을경우 0시0분보다 1분 전인 23시로 설정해준다.
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 = M + 60;
H--;
if (H < 0) H = 23;
}
System.out.println(H);
System.out.println(M-45);
}
}
'공부노트 > 백준알고리즘' 카테고리의 다른 글
[Java, 자바] 백준알고리즘 단계별로 풀기 - 6단계 (0) | 2020.06.05 |
---|---|
[Java, 자바] 백준알고리즘 단계별로 풀기 - 5단계 (0) | 2020.06.01 |
[Java, 자바] 백준알고리즘 단계별로 풀기 - 3단계 (0) | 2020.05.29 |
[Java, 자바] 백준알고리즘 단계별로 풀기 - 1단계 (2) | 2020.05.26 |