문제
오늘은 혜아의 면접 날이다. 면접 준비를 열심히 해서 앞선 질문들을 잘 대답한 혜아는 이제 마지막으로 칠판에 직접 코딩하는 문제를 받았다. 혜아가 받은 문제는 두 수를 더하는 문제였다. C++ 책을 열심히 읽었던 혜아는 간단히 두 수를 더하는 코드를 칠판에 적었다. 코드를 본 면접관은 다음 질문을 했다. “만약, 입출력이 𝑁 바이트 크기의 정수라면 프로그램을 어떻게 구현해야 할까요?”
혜아는 책에 있는 정수 자료형과 관련된 내용을 기억해 냈다. 책에는 long int는 4 바이트 정수까지 저장할 수 있는 정수 자료형이고 long long int는 8 바이트 정수까지 저장할 수 있는 정수 자료형이라고 적혀 있었다. 혜아는 이런 생각이 들었다. “int 앞에 long을 하나씩 더 붙일 때마다 4 바이트씩 저장할 수 있는 공간이 늘어나는 걸까? 분명 long long long int는 12 바이트, long long long long int는 16 바이트까지 저장할 수 있는 정수 자료형일 거야!” 그렇게 혜아는 당황하는 면접관의 얼굴을 뒤로한 채 칠판에 정수 자료형을 써 내려가기 시작했다.
혜아가 𝑁 바이트 정수까지 저장할 수 있다고 생각해서 칠판에 쓴 정수 자료형의 이름은 무엇일까?
입력
첫 번째 줄에는 문제의 정수 𝑁 이 주어진다. (4≤𝑁≤1000 ; 𝑁 은 4 의 배수)
출력
혜아가 𝑁 바이트 정수까지 저장할 수 있다고 생각하는 정수 자료형의 이름을 출력하여라.
예제 입력 1 복사
4
예제 출력 1 복사
long int
예제 입력 2 복사
20
예제 출력 2 복사
long long long long long int
노트
출력에서 long과 long, long과 int 사이에는 공백이 하나씩 들어간다.
실제로 C++에서 각 정수 자료형이 저장할 수 있는 수의 크기는 환경에 따라 달라질 수 있다. 덧붙여, 실제로 문제 내용과 같이 long long long int와 같은 자료형을 사용한 코드를 GCC의 C++ 컴파일러를 사용해 컴파일하려고 할 경우 'long long long' is too long for GCC라는 에러 메시지와 함께 컴파일되지 않는다.
정답
import java.io.*;
import java.util.*;
public class Main{
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
// StringTokenizer st = new StringTokenizer(br.readLine());
Long n = Long.parseLong(br.readLine());
for (int i=0; i<(n/4); i++){
System.out.print("long ");
}
System.out.println("int");
}
}
'알고리즘 단련장 > 백준' 카테고리의 다른 글
[백준] 문제 제출시 "기다리는 중" 오류 (1) | 2024.07.15 |
---|---|
[백준] 10807 개수 세기 자바 풀이 (0) | 2024.07.15 |
[백준] 15552 빠른 A+B 자바 풀이 (0) | 2024.07.15 |
[백준] 25304 영수증 자바 풀이 (0) | 2024.07.15 |
[백준] 문제 풀면 깃허브로 자동 커밋하기 (+프로그래머스도) (0) | 2024.07.10 |