boj
-
[BOJ/백준] 1550번 16진수 단위 테스크 코드 (JAVA/자바)2022.03.17
-
[BOJ/백준] 1550번 16진수 문제 풀이 (JAVA/자바)2022.03.17
-
[BOJ/백준] 2557번 Hello World 문제 풀이 (JAVA/자바)2021.12.22
-
[BOJ/백준] 1000번 A+B 문제 풀이 (JAVA/자바)2021.12.22
-
[BOJ/백준] 1001번 A-B 문제 풀이 (JAVA/자바)2021.12.22
[BOJ/백준] 1550번 16진수 단위 테스크 코드 (JAVA/자바)
1. 문제 1550번 16진수 단위 테스크 코드
문제 풀이
2. 단위 테스트 설명
먼저 단위 테스트 간략하게 설명하면
단위 테스트 : 하나의 모듈을 기준으로 독립적으로 진행되는 가장 작은 단위의 테스트 , 하나의 기능 또는 메소드
백준 16진수 문제를 풀면서 내가 푼 소스 코드가 어디가 틀렸는지 알 수 없어서 하나하나 테스트하기에 까다로워서 단위 테스트 코드를 한번 만들어 보았다.
3. 소스 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
public class x16 {
// 16진수 단위 테스트
static int my16(String x16){
// x16 : 입력값, result : 출력값
// .. 내가 만든 소스코드 넣는 곳
return result;
}
public static void main(String[] args) {
for (int i = 0; i < 16777216; i++) {
if(my16(Integer.toHexString(i)) !=
Integer.parseInt(Integer.toHexString(i), 16) ) {
System.out.println("i : "+i);
System.out.println("my16 : "+ my16(Integer.toHexString(i)));
System.out.println("공식 16진수 변환 : "+Integer.toHexString(i)+" "
+"16>10진수 변환 "+Integer.parseInt(Integer.toHexString(i), 16));
break;
}
}
System.out.println("suscess");
}
}
|
cs |
my16 함수에 자기가 만든 소스를 넣어서 테스트 해볼 수 있는데 이전에 정답으로 풀었던 제 소스 코드를 넣으면
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
public class x16 {
// 16진수 단위 테스트
static int my16(String y){
int yChar;
int sum = 0;
int tenMultiply;
for (int i = 0; i < y.length(); i++) {
yChar = y.charAt(i)-0;
tenMultiply=1;
for (int j = y.length()-1; j > i; j--) {
tenMultiply *= 16;
}
if(48 < yChar && yChar < 58) {
sum += (yChar-48) * tenMultiply;
}
else if(64 < yChar && yChar < 71) {
sum += (yChar-55) * tenMultiply;
}
}
return sum;
}
public static void main(String[] args) {
for (int i = 0; i < 16777216; i++) {
if(my16(Integer.toHexString(i).toUpperCase()) !=
Integer.parseInt(Integer.toHexString(i).toUpperCase(), 16) ) {
System.out.println("index : "+i);
System.out.println("내가 만든 16진수 변환값 : "+ my16(Integer.toHexString(i).toUpperCase()));
System.out.println("공식 16진수 변환값 : "+Integer.toHexString(i).toUpperCase()+", "
+"공식 10진수 변환값 "+Integer.parseInt(Integer.toHexString(i).toUpperCase(), 16));
break;
}
}
System.out.println("suscess");
}
}
|
cs |
결과값 : 내가 정답으로 제출한 소스 코드로 함수에 넣어서 테스트해봤는데 정상적으로 if문에 걸리지 않아 테스트 완료되었다.
이처럼 sum 을 출력값 y를 입력값으로 두었는데 그값을 위처럼 바꿔주기만 하면 테스트 할 수 있다.
하지만 이게 틀린 소스 코드라면?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
public class x16 {
// 16진수 단위 테스트
static int my16(String y){
int yChar;
int sum = 0;
int tenMultiply;
for (int i = 0; i < y.length(); i++) {
yChar = y.charAt(i)-0;
tenMultiply=1;
for (int j = y.length()-1; j > i; j--) {
tenMultiply *= 16;
}
if(48 < yChar && yChar < 58) {
sum += (yChar-48) * tenMultiply;
}
else if(64 < yChar && yChar < 71) {
sum += (yChar-56) * tenMultiply; // error
}
}
return sum;
}
public static void main(String[] args) {
for (int i = 0; i < 16777216; i++) {
if(my16(Integer.toHexString(i).toUpperCase()) !=
Integer.parseInt(Integer.toHexString(i).toUpperCase(), 16) ) {
System.out.println("index : "+i);
System.out.println("내가 만든 16진수 변환값 : "+ my16(Integer.toHexString(i).toUpperCase()));
System.out.println("공식 16진수 변환값 : "+Integer.toHexString(i).toUpperCase()+", "
+"공식 10진수 변환값 "+Integer.parseInt(Integer.toHexString(i).toUpperCase(), 16));
break;
}
}
System.out.println("suscess");
}
}
|
cs |
16진수 값에 -55 값에서 -56으로 바꿔주었다. 그 결과 A를 입력했을때 10으로 나오는게 아닌 9로 나온다
결과값
4. 단위 테스트 코드 설명
먼저 for문을 16777216번 돌리는 이유 : 백준 입력값 6글자로 제한되어 있어 16진수 최대값인 FFFFFF 변환하면 16777215이 최대값이기 때문이다.
Integer.toHexString(i) : 16진수 > 10진수 변환
toUpperCase() : toHexString 함수를 이용하면 16진수 문자열이 소문자로 나오는 값을 대문자로 변환
(백준에서는 대문자로 풀이)
Integer.parsInt(Integer.toHexString(i).toUpperCase(), 16) : pareInt(String, 16) ; 16진수 문자열을 10진수 값으로 변환
5. 결론
사실 16진수 문제는 Integer.pareInt로 간단하게 풀 수 있지만
이 문제의 자기가 풀어본 소스 코드가 틀리다면 어떤게 틀렸는지 확인하는것도 중요하다.
'백준 문제 풀이(Java)' 카테고리의 다른 글
[BOJ/백준] 1550번 16진수 문제 풀이 (JAVA/자바) (0) | 2022.03.17 |
---|---|
[BOJ/백준] 2557번 Hello World 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1000번 A+B 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1001번 A-B 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1550번 16진수 문제 풀이 (JAVA/자바)
1. 문제 1550번 16진수 : 16진수의 개념을 알아야 되는 문제
이 문제를 풀면서 문제에 단위 테스트 코드를 적용해보았던 문제였다.
난이도 : 브론즈 V (solved.ac 티어)
16진수 단위 테스트 코드가 궁금하시면 아래 링크를 참조해주세요.
문제 링크 : https://www.acmicpc.net/problem/1550
2. 문제 풀이
제 풀이는 BufferedReader(입력)와 BufferedWriter(출력), 16진수 개념, 아스키 코드(char) 를 이해해야 됩니다.
BufferedReader(입력)와 BufferedWriter(출력)는 백준에서 풀이할때 Scanner와 System.out 보다 더 빠르게 입출력하기 위해 사용했습니다. 이 글에선 따로 설명하진 않겠습니다.
tenMultiply는 16진수 지수로 곱하기 위한 수이며
String.charAt(index) 는 index 별로 아스키코드값을 얻을 수 있습니다.
아스키코드 표를 보시면 49~57는 1~9 숫자값을 나타냅니다. 0은 따로 계산할 필요 없어서 포함시키지 않았습니다.
또한 문제에 나오는 65~70는 A~F 값을 나타냅니다.
이를 이용하여 yChar-48 = 1~9 , yChar-55 = 10~15 값을 나타냅니다.
3. 소스 코드 및 풀이 인증
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
public class Main {
public static void main(String[] args) throws IOException{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
String y = br.readLine();
int yChar;
long sum = 0;
int tenMultiply;
for (int i = 0; i < y.length(); i++) {
yChar = y.charAt(i)-0;
tenMultiply=1;
for (int j = y.length()-1; j > i; j--) {
tenMultiply *= 16;
}
if(48 < yChar && yChar < 58) {
sum += (yChar-48) * tenMultiply;
}
else if(64 < yChar && yChar < 71) {
sum += (yChar-55) * tenMultiply;
}
}
bw.write(sum+"\n");
bw.flush();
bw.close();
}
}
|
cs |
'백준 문제 풀이(Java)' 카테고리의 다른 글
[BOJ/백준] 1550번 16진수 단위 테스크 코드 (JAVA/자바) (0) | 2022.03.17 |
---|---|
[BOJ/백준] 2557번 Hello World 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1000번 A+B 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1001번 A-B 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 2557번 Hello World 문제 풀이 (JAVA/자바)
1. 문제 : 2557번 Hello World : 출력의 기초가 되는 문제
많은 프로그래밍 언어 서적에서 맨 처음 소개하는 예제입니다.
난이도 : 브론즈 V (solved.ac 티어)
문제 링크 : https://www.acmicpc.net/problem/2557
2. 문제 풀이
이 문제는 출력하는 방법을 알면 풀 수 있는 문제이다.
3. 소스 코드 및 풀이 인증
1
2
3
4
5
6
7
8
|
public class Main{
public static void main(String[] args) {
System.out.print("Hello World!");
}
}
|
cs |
'백준 문제 풀이(Java)' 카테고리의 다른 글
[BOJ/백준] 1550번 16진수 단위 테스크 코드 (JAVA/자바) (0) | 2022.03.17 |
---|---|
[BOJ/백준] 1550번 16진수 문제 풀이 (JAVA/자바) (0) | 2022.03.17 |
[BOJ/백준] 1000번 A+B 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1001번 A-B 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1000번 A+B 문제 풀이 (JAVA/자바)
1. 문제 : 1000번 A+B : 두 숫자를 입력받아 더하고 출력하는 문제
난이도 : 브론즈 V (solved.ac 티어)
문제 링크 : https://www.acmicpc.net/problem/1000
2. 문제 풀이
이 문제는 키보드를 이용해 숫자를 입력하는 방법과 출력하는 방법만 알면 풀 수 있는 문제이다.
Scanner(입력)에 더 자세한 설명 : https://programming-enjoy.tistory.com/7
3. 소스 코드 및 풀이 인증
1
2
3
4
5
6
7
8
|
public class Main{
public static void main(String[] args) {
java.util.Scanner in=new java.util.Scanner(System.in);
int a=in.nextInt(); int b=in.nextInt();
System.out.println(a+b);
}
}
|
cs |
'백준 문제 풀이(Java)' 카테고리의 다른 글
[BOJ/백준] 1550번 16진수 단위 테스크 코드 (JAVA/자바) (0) | 2022.03.17 |
---|---|
[BOJ/백준] 1550번 16진수 문제 풀이 (JAVA/자바) (0) | 2022.03.17 |
[BOJ/백준] 2557번 Hello World 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1001번 A-B 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1001번 A-B 문제 풀이 (JAVA/자바)
1. 문제 : 1001번 A-B : 두 숫자를 입력받아 빼고 출력하는 문제
난이도 : 브론즈 V (solved.ac 티어)
문제 링크 : https://www.acmicpc.net/problem/1001
2. 문제 풀이
이 문제는 키보드를 이용해 숫자를 입력하는 방법과 출력하는 방법만 알면 풀 수 있는 문제이다.
Scanner(입력)에 더 자세한 설명 : https://programming-enjoy.tistory.com/7
3. 소스 코드 및 풀이 인증
1
2
3
4
5
6
7
8
|
public class Main{
public static void main(String[] args) {
java.util.Scanner in=new java.util.Scanner(System.in);
int a=in.nextInt(); int b=in.nextInt();
System.out.println(a-b);
}
}
|
cs |
'백준 문제 풀이(Java)' 카테고리의 다른 글
[BOJ/백준] 1550번 16진수 단위 테스크 코드 (JAVA/자바) (0) | 2022.03.17 |
---|---|
[BOJ/백준] 1550번 16진수 문제 풀이 (JAVA/자바) (0) | 2022.03.17 |
[BOJ/백준] 2557번 Hello World 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |
[BOJ/백준] 1000번 A+B 문제 풀이 (JAVA/자바) (0) | 2021.12.22 |