본문 바로가기
Algorithm/Baekjoon

[백준] 1001번 : A - B - Java

by unknownomad 2021. 12. 22.

https://www.acmicpc.net/problem/1001

 

1001번: A-B

두 정수 A와 B를 입력받은 다음, A-B를 출력하는 프로그램을 작성하시오.

www.acmicpc.net


 


주의점

  • 입력이 공백 단위로 주어짐

비슷한 문제 유형

https://unknownomad.tistory.com/34

 

[백준] 1000번: A+B - Java

https://www.acmicpc.net/problem/1000 1000번: A+B 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오. www.acmicpc.net 문제 주의점: 입력이 공백 단위로 주어진다. 입력 방식 1. Scanner..

unknownomad.tistory.com


입력 방식

1. Scanner

  • 가장 기본적인 입력 방식
  • in.next(): 문자열 입력 시 공백 전까지만 받음(에러나는 경우 多)
  • in.nextLine(): 문자열 입력 시 Enter 입력 전까지만 받음(사용 권장)

 

2. BufferedReader

  • Scanner 입력 방식보다 훨씬 빠른 성능

2.1. 문자열 받는 대표적인 방법

  • read():  한 문자만 읽어오기
  • readLine(): 한 행 읽어오기(사용 권장)
    ➡ readLine()은 한 행을 전부 읽기에 공백 단위로 입력해준 문자열을 다시 공백 단위로 분리해줘야 함

2.2. 문자열 분리 방법

2.2.1. StringTokenizer 클래스

  • split()보다 성능 좋음(단순 규칙으로 문자열 분리하거나 데이터가 더 많아질 때 추천)

2.2.2. split()

  • StringTokenizer 클래스와 split() 모두 문자열을 반환하기에 자료형 타입 확인 후 형변환 유의하기
  • double형으로 풀면 나머지가 정수로 나와도 소수점까지 같이 출력되어 오답으로 처리됨

 

풀이

1. Scanner

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
		
        Scanner in = new Scanner(System.in);
        
        int A = in.nextInt();
        int B = in.nextInt();
        
        System.out.println(A - B);
		
        in.close();
    }
}

 

2. BufferedReader

2.1. StringTokenizer 클래스

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

import com.ibm.icu.util.StringTokenizer;

public class Main {
    public static void main(String[] args) throws IOException {
		
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		
        //long ver.
        String str = br.readLine();
        StringTokenizer st = new StringTokenizer(str, " ");
        //short ver.
        StringTokenizer st1 = new StringTokenizer(br.readLine(), " ");
		
        int A = Integer.parseInt(st.nextToken()); //nextToken(): 문자열 반환
        int B = Integer.parseInt(st.nextToken());
		
        System.out.println(A - B);
    }
}

 

2.2. split()

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main {
    public static void main(String[] args) throws IOException {
		
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		
        String[] str = br.readLine().split(" ");
		
        int A = Integer.parseInt(str[0]);
        int B = Integer.parseInt(str[1]);
		
        System.out.println(A - B);
    }
}

성능 순서

  1. BufferedReader + StringTokenizer
  2. BufferedReader + split()
  3. Scanner

 


출처 : https://st-lab.tistory.com/14?category=827050 

'Algorithm > Baekjoon' 카테고리의 다른 글

[백준] 1008번 : A / B - Java  (0) 2022.01.03
[백준] 10998번 : A x B - Java  (0) 2021.12.23
[백준] 1000번 : A + B - Java  (0) 2021.12.21
[백준] 10172번 : Dogs - Java  (0) 2021.12.20
[백준] 10171번 : Cats - Java  (0) 2021.12.16

댓글