본 문제는 python 의 빠른 기초 학습을 위해 설계된 문제로서 python 코드 제출을 기준으로 설명되어 있습니다.
------
정수 1개를 입력받아
2배 곱한 값을 출력해보자.
참고
*2 를 계산해 출력해도 되지만,
2진수로 저장된 값을 왼쪽이나 오른쪽으로 1비트씩 이동시켜,
2 배로 곱하거나, 2 로 나눈 효과를 만들어주는 비트 시프트 연산자 <<, >> 를 사용할 수도 있다.
컴퓨터 내부에는 모든 데이터들이 2진수 형태로 저장되기 때문에,
그 값들을 왼쪽이나 오른쪽으로 1 비트 만큼 밀어 이동시키면,
원래 값의 2 배로 커지거나 1/2 로 작아지게 된다.
왼쪽으로(<<) 비트 시프트가 되어 오른쪽에 새로운 비트가 추가될 때에는
무조건 0 이 추가되고, 왼쪽으로 자릿수를 넘어가는 비트는 삭제된다.
오른쪽으로(>>) 비트 시프트가 되어 왼쪽에 새로운 비트가 추가될 때에는
가장 왼쪽에 있던 비트가 0 인 경우에는 0 이 추가되고,
가장 왼쪽에 있던 비트가 1 인 경우에는 1 이 추가 된다.
그리고 가장 오른쪽에 있던 비트는 삭제된다.
예시
n = 10
print(n<<1) #10 을 2 배 한 값인 20 이 출력된다.
print(n>>1) #10 을 반으로 나눈 값인 5 가 출력된다.
print(n<<2) #10 을 4 배 한 값인 40 이 출력된다.
print(n>>2) #10 을 반으로 나눈 후 다시 반으로 나눈 값인 2 가 출력된다.
정수 10 의 2진수 표현은 000 ... 1010 이다.
10<<1 을 계산하면 000 ... 10100 이 된다. 이 값은 10진수로 20 이다.
10>>1 을 계산하면 000 ... 101 이 된다. 이 값은 10진수로 5 이다.
n = 10 과 같이 키보드로 입력받지 않고 직접 작성해 넣은 코드에서,
숫자로 시작하는 단어(식별자, identifier)는 자동으로 수로 인식된다.
n = 10 에서 10 은 10진수 정수 값으로 인식된다.
변수 n 에 문자열을 저장하고 싶다면, n = "10" 또는 n = '10' 으로 작성해 넣으면 되고,
n = 10.0 으로 작성해 넣으면 자동으로 실수 값으로 저장된다.
n = 0o10 으로 작성해 넣으면 8진수(octal) 10 으로 인식되어 10진수 8 이 저장되고,
n = 0xf 나 n = 0XF 으로 작성해 넣으면 16진수(hexadecimal) F로 인식되어 10진수 15 로 저장된다.
**
python에서 실수 값에 대한 비트 시프트 연산은 허용되지 않고 오류가 발생한다.
(실수 값도 컴퓨터 내부적으로는 2진수 형태로 저장되고 비트 시프트 처리가 될 수 있지만,
python 에서는 허용하지 않는다.)