이 영역을 누르면 첫 페이지로 이동
Stranger's LAB 블로그의 첫 페이지로 이동

Stranger's LAB

페이지 맨 위로 올라가기

Stranger's LAB

프로그래밍과 관련하여 다양한 알고리즘 문제를 풀어보고, 프로그래밍 언어를 이해해 볼 수 있도록 돕고자 만든 블로그 입니다.

[백준] 1330번 : 두 수 비교하기 - JAVA [자바]

  • 2020.02.13 21:40
  • JAVA - 백준 [BAEK JOON]/조건문
글 작성자: ST_
728x90




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

 

1330번: 두 수 비교하기

두 정수 A와 B가 주어졌을 때, A와 B를 비교하는 프로그램을 작성하시오.

www.acmicpc.net



 

 




  • 문제

 

 

 

if 조건문의 기초 중의 기초다!

 

※ 주의할점

  • 입력은 공백 한 칸으로 구분되어 두 정수가 주어진다.

 







  • 2가지 풀이 방법을 제시한다.

 

모두 잘 아는 Scanner 로 입력받는 방법을 통해 풀어보고 다른 하나는 BufferedReader로 풀어보려 한다.

또한 추가로 삼항연산자를 이용하여 푸는 방법 또한 알려주고자 한다.

 

그리고 결과를 보면서 두 입력방법의 성능 차이는 많이 난다는 점을 알려주고자 한다.

 

 

 

 

 




  • 풀이

 



- 방법 1 

 

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();
		
		in.close();
        
		if(A>B) System.out.println(">");
		else if(A<B) System.out.println("<");
		else System.out.println("==");

	}

}

 

 

가장 기초적인 방법이다.

이 부분은 따로 설명을 하지 않아도 되리라 생각한다.

 

 

다만 조건문을 좀 더 획기적으로 줄일 수 있는 방법이 있다!

이름하여 "삼항연산자" 다.

 

기본 문법은 아래와 같다.

변수 = (조건문) ? (true 일 때의 연산) : (false 일 때의 연산) ;



예로 if else 문으로 다음과 같은 식이 있다고 생각해보자.

int a = 1;
int b = 2;
int c;

if( a > b ){
	c = a;
} else {
	c = b;
}


a와 b 중 큰 값을 c 에 담으려 할 때 저렇게 쓸 수 있다.

하지만 줄도 너무 길어지고 보기 지저분할 수 있으니 위에서 말한 삼항연산자를 이용해보자.



int a = 1;
int b = 2;

int c = (a>b) ? a : b ;



엄청나지 않은가? 적어도 2줄에서 4줄을 필요로 하는 조건문이 단 하나의 식으로 정리가 된다.

 

물론 삼항연산자를 중첩할 수도 있다.

이는 본 문제를 풀면서 보자.



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();
		
		in.close();
        
		String str = (A>B) ? ">" : ((A<B) ? "<" : "==" );
		System.out.println(str);
	}

}



이와 같이 A>B 가 true 일 때 > 라는 문자열을 str 에 저장하고

false 일 경우 삼항연산자를 한 번 더 중첩하여 A<B 라는 조건식에 대해 검사하여 true 일 때와 false 일 때의 연산을 해주면 된다.

 

근데 굳이 String str 이라는 변수를 생성할 필요 없이 print 메소드에 넣어서 출력할 수는 없을까?

정답은 가능하다.

아래 코드를 보면 바로 이해할 수 있을 것이다.

 

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();
		
		in.close();
        
		System.out.println((A>B) ? ">" : ((A<B) ? "<" : "==" ));
	}

}




 

이와 같이 삼항연산자를 사용하면 코드를 간략화할 수 있어서 간단한 조건문인 경우 가독성을 높일 수 있다는 장점이 있다.

(속도가 빨라진다거나 그런 건 아니다. 하지만 가독성은 개발자 입장에서는 매우 중요하기 때문에..)

 



 


 

- 방법 2 

 

 

BufferedReader 을 쓰는 방식이다.

 

readLine() 을 통해 입력받아 연산하는 방법 두 가지를 설명할 것이다.

앞서 말했듯이 readLine() 은 한 행을 전부 읽기 때문에 공백 단위로 입력해 준 문자열을 공백단위로 분리해주어야 문제를 풀 수 있을 것이다.

 

문자열 분리 방법 두 가지로 풀어보자.

  1. StringTokenizer 클래스를 이용하여 분리해주는 방법
  2. split() 을 이용하는 방법

 

그리고 반드시 자료형 타입을 잘 보아야 한다.

st.nextToken() 은 문자열을 반환하니 Integer.parseInt()로 int 형으로 변환시켜준다.

 

(추가로 삼항연산자로 풀이하겠다.)



// 방법 2-1

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

public class Main {

	public static void main(String[] args) throws IOException {
        
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
 
 		String str = br.readLine();
		StringTokenizer st = new StringTokenizer(str," ");
		int A = Integer.parseInt(st.nextToken());
		int B = Integer.parseInt(st.nextToken());
		
		System.out.println((A>B) ? ">" : ((A<B) ? "<" : "==" ));
	
/*    
굳이 String 변수 생성 안하고 입력과 동시에 구분자로 분리해줘도 된다.

		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine()," ");
		int A = Integer.parseInt(st.nextToken());
		int B = Integer.parseInt(st.nextToken());
		
		System.out.println((A>B) ? ">" : ((A<B) ? "<" : "==" )); 
        
*/
	}
}

 

 

두 번째 방법은 br.readLine() 을 통해 읽어온 것을 split(" ") 하여 공백 단위로 나눠준 뒤 String 배열에 각각 저장하는 방법이다.

 

// 방법 2-2

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

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) ? ">" : ((A<B) ? "<" : "==" ));

	}

}

 

 

 

 




  • 성능 차이

 

 


위에서부터 순서대로

 

채점 번호 : 17659456  -  BufferedReader + split()  사용

채점 번호 : 17659445  -  BufferedReader + StringTokenizer  사용

채점 번호 : 17659401  -  Scanner  사용

 

시간을 보면 BufferedReader 와 Scanner 의 성능 차이가 확연하게 나는 것을 볼 수가 있다.

 

 

 

 

 

 




  • 정리

 

오늘은  기본적인 삼항연산자에 대해서 같이 알아보았다.

조건식이 복잡하지 않은 경우 삼항연산자를 쓰면 편리한 점이 여러모로 많으므로 잘 익혀두었으면 한다.

 

물론 조건식이 복잡하다면 삼항연산자보다는 if-else 문으로 해주는 게 더 가독성이 좋으니

상황을 보고 판단하시길 바란다!



 

 

저작자표시 비영리 변경금지 (새창열림)

'JAVA - 백준 [BAEK JOON] > 조건문' 카테고리의 다른 글

[백준] 2525번 : 오븐 시계 - JAVA [자바]  (18) 2022.07.22
[백준] 14681번 : 사분면 고르기 - JAVA [자바]  (2) 2020.03.17
[백준] 2884번 : 알람 시계 - JAVA [자바]  (24) 2020.02.14
[백준] 2753번 : 윤년 - JAVA [자바]  (19) 2020.02.13
[백준] 9498번 : 시험 성적 - JAVA [자바]  (0) 2020.02.13

댓글

이 글 공유하기

  • 구독하기

    구독하기

  • 카카오톡

    카카오톡

  • 라인

    라인

  • 트위터

    트위터

  • Facebook

    Facebook

  • 카카오스토리

    카카오스토리

  • 밴드

    밴드

  • 네이버 블로그

    네이버 블로그

  • Pocket

    Pocket

  • Evernote

    Evernote

다른 글

  • [백준] 14681번 : 사분면 고르기 - JAVA [자바]

    [백준] 14681번 : 사분면 고르기 - JAVA [자바]

    2020.03.17
  • [백준] 2884번 : 알람 시계 - JAVA [자바]

    [백준] 2884번 : 알람 시계 - JAVA [자바]

    2020.02.14
  • [백준] 2753번 : 윤년 - JAVA [자바]

    [백준] 2753번 : 윤년 - JAVA [자바]

    2020.02.13
  • [백준] 9498번 : 시험 성적 - JAVA [자바]

    [백준] 9498번 : 시험 성적 - JAVA [자바]

    2020.02.13
다른 글 더 둘러보기

정보

Stranger's LAB 블로그의 첫 페이지로 이동

Stranger's LAB

  • Stranger's LAB의 첫 페이지로 이동

검색

나의 외부 링크

  • st-github

공지사항

  • 공지 - 블로그 사용 설명서

메뉴

  • 홈
  • 방명록

카테고리

  • 전체 카테고리 (267)
    • Java (5)
    • JAVA - 백준 [BAEK JOON] (177)
      • 입출력과 사칙연산 (14)
      • 조건문 (7)
      • 반복문 (11)
      • 1차원 배열 (7)
      • 함수 (3)
      • 문자열 (10)
      • 기본 수학 1 (8)
      • 기본 수학 2 (6)
      • 2차원 배열 (0)
      • 정렬 (10)
      • 재귀 (4)
      • 브루트 포스 (5)
      • 집합과 맵 (0)
      • 기하 1 (5)
      • 정수론 및 조합론 (12)
      • 백트래킹 (8)
      • 동적 계획법 1 (15)
      • 누적 합 (0)
      • 그리디 알고리즘 (5)
      • 스택 (5)
      • 큐, 덱 (7)
      • 분할 정복 (9)
      • 이분 탐색 (7)
      • 기타 문제 (17)
      • 별 찍기 문제 모음 (2)
    • C++ - 백준 [BAEK JOON] (46)
      • 입출력과 사칙연산 (14)
      • 조건문 (7)
      • 반복문 (11)
      • 1차원 배열 (7)
      • 함수 (3)
      • 문자열 (0)
      • 기타 문제 (4)
    • 자료구조 (18)
      • Java (18)
    • 알고리즘 (11)
      • Java (11)
    • 프로그래밍 기초 (6)
    • 이모저모 (2)
    • 일상의 글 (2)

최근 글

정보

ST_의 Stranger's LAB

Stranger's LAB

ST_

블로그 구독하기

  • 구독하기
  • 네이버 이웃 맺기
  • RSS 피드

방문자

  • 전체 방문자
  • 오늘
  • 어제

티스토리

  • 티스토리 홈
  • 이 블로그 관리하기
  • 글쓰기
Powered by Tistory / Kakao. Copyright © ST_.

티스토리툴바