코딩테스트
[Coding Test] 백준 - 코딩은 체육과목 입니다
Rowen Jobs
2023. 3. 11. 02:16
728x90
반응형
문제
오늘은 혜아의 면접 날이다. 면접 준비를 열심히 해서 앞선 질문들을 잘 대답한 혜아는 이제 마지막으로 칠판에 직접 코딩하는 문제를 받았다. 혜아가 받은 문제는 두 수를 더하는 문제였다. C++ 책을 열심히 읽었던 혜아는 간단히 두 수를 더하는 코드를 칠판에 적었다. 코드를 본 면접관은 다음 질문을 했다. “만약, 입출력이 바이트 크기의 정수라면 프로그램을 어떻게 구현해야 할까요?”
혜아는 책에 있는 정수 자료형과 관련된 내용을 기억해 냈다. 책에는 long int는 4 바이트 정수까지 저장할 수 있는 정수 자료형이고 long long int는 8 바이트 정수까지 저장할 수 있는 정수 자료형이라고 적혀 있었다. 혜아는 이런 생각이 들었다. “int 앞에 long을 하나씩 더 붙일 때마다 4 바이트씩 저장할 수 있는 공간이 늘어나는 걸까? 분명 long long long int는 12 바이트, long long long long int는 16 바이트까지 저장할 수 있는 정수 자료형일 거야!” 그렇게 혜아는 당황하는 면접관의 얼굴을 뒤로한 채 칠판에 정수 자료형을 써 내려가기 시작했다.
혜아가 바이트 정수까지 저장할 수 있다고 생각해서 칠판에 쓴 정수 자료형의 이름은 무엇일까?
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
// 총 바이트가 되는 수를 변수에 담는다
int temp = sc.nextInt();
// 4 바이트에 1개의 long 이 찍히기 때문에 4 를 나눈 값을 변수에 담아준다
int long_cnt = temp / 4;
// 변수에 담은 만큼 반복문을 돌리고 마지막에는 int 로 마무리 해준다
for(int i = 0; i < long_cnt; i++){
if(long_cnt - 1 == i){
System.out.print("long");
System.out.print(" ");
System.out.print("int");
}else{
System.out.print("long");
System.out.print(" ");
}
}
}
}
728x90