문제
오늘은 혜아의 면접 날이다. 면접 준비를 열심히 해서 앞선 질문들을 잘 대답한 혜아는 이제 마지막으로 칠판에 직접 코딩하는 문제를 받았다. 혜아가 받은 문제는 두 수를 더하는 문제였다. C++ 책을 열심히 읽었던 혜아는 간단히 두 수를 더하는 코드를 칠판에 적었다. 코드를 본 면접관은 다음 질문을 했다. “만약, 입출력이 N바이트 크기의 정수라면 프로그램을 어떻게 구현해야 할까요?”
혜아는 책에 있는 정수 자료형과 관련된 내용을 기억해 냈다. 책에는 long int는 4바이트 정수까지 저장할 수 있는 정수 자료형이고 long long int는 8바이트 정수까지 저장할 수 있는 정수 자료형이라고 적혀 있었다. 혜아는 이런 생각이 들었다. “int 앞에 long을 하나씩 더 붙일 때마다 4바이트씩 저장할 수 있는 공간이 늘어나는 걸까? 분명 long long long int는 12바이트, long long long long int는 16바이트까지 저장할 수 있는 정수 자료형일 거야!” 그렇게 혜아는 당황하는 면접관의 얼굴을 뒤로한 채 칠판에 정수 자료형을 써 내려가기 시작했다.
혜아가 N바이트 정수까지 저장할 수 있다고 생각해서 칠판에 쓴 정수 자료형의 이름은 무엇일까?
입력
첫 번째 줄에는 문제의 정수 N이 주어진다. (4≤ N ≤1000; N은 4의 배수)
출력
혜아가 N바이트 정수까지 저장할 수 있다고 생각하는 정수 자료형의 이름을 출력하여라.
풀이
처음에 4 가 들어오면 long int, 8이 들어오면 long long int 인걸 봤을때
4의 배수를 기준으로 long을 붙여주면 된다고 생각해 내면된다
그래서 첫번째 줄에 받은 숫자를 4로 나누어주면 몫이 나온다
이 몫이 반복하는 숫자라고 생각하면 된다
"long" 이라는 스트링 에 .repeat() 메서드를 사용하여
반복하게 해주는걸로 마무리 해줬다
코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws IOException {
final BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine()) / 4;
System.out.print("long ".repeat(n) + "int");
}
}
'Algorithm' 카테고리의 다른 글
[Algorithm] 백준 10807번 : 개수 세기 (0) | 2023.02.27 |
---|---|
[Algorithm] 백준 15552번 : 빠른 A+B (0) | 2023.02.25 |
[Algorithm] 백준 25304번 : 연수증 (0) | 2023.02.19 |
[Algorithm] 백준 8393번 : 합 (0) | 2023.02.18 |
[Algorithm] 백준 10950번 : A+B -3 (0) | 2023.02.15 |