인프런 커뮤니티 질문&답변

김민경님의 프로필 이미지
김민경

작성한 질문수

(2025) 일주일만에 합격하는 정보처리기사 실기

(기출) 2024년 1회 코드해석 문제

쉬프트연산자 관련 질문입니다

해결된 질문

작성

·

56

0

강의 커리큘럼 내 잘 안나오는 문법에서 설명해주신 쉬프트 연산자는

a = 5 // 0101

result = 5 << 1 // 1010

이렇게 2진수의 자릿수는 안바뀌었는데

기출문제 풀이는

v3 = 11101

v3 << 2 = 1110100

으로 왼쪽 자릿수가 지워지지않고 뒤에 00만 더 붙는 형식이어서 헷갈립니다.

2만큼 왼쪽 자릿수를 지우고 미는거라고 이해했었는데 자릿수가 유지되는 기준이 궁금합니다

답변 2

1

주말코딩님의 프로필 이미지
주말코딩
지식공유자

미는게 없어지는 것이 아닙니다.

실제로 없어지려면, 우리 현실의 컴퓨터 32비트나 64비트 기준으로 전체를 1로 채우고 밀어야 하는데, 저 예제는 몇 비트 안되어서 해당이 안됩니다.

그냥 2씩 곱하시면 됩니다. (미는 만큼 2의 제곱 수를 곱하면 됨)

0

안녕하세요, 인프런 AI 인턴입니다. 김민경님.

쉬프트 연산자에 대해 이해하기 어려운 점이 있으셨군요. 쉬프트 연산자, 특히 왼쪽 쉬프트 << 연산은 비트의 이동에 따라 값이 달라질 수 있습니다.

  1. 쉬프트 연산자의 기본 원리:

    • 왼쪽 쉬프트(<<): 지정한 비트 수만큼 비트를 왼쪽으로 이동합니다. 예를 들어, 5<<1 하면 비트가 왼쪽으로 한 칸 이동하여 1010(즉 10진수로 10)이 됩니다. 이는 5(이진수 0101)를 한 칸 왼쪽으로 밀며, 오른쪽 빈자리에 0이 채워지는 것입니다.
  2. 기출 문제의 이해:

    • 주신 예제에서 v3 = 11101이고 v3 << 21110100이 됩니다. 이 경우 11101(5비트)2비트 왼쪽으로 이동시키며 0을 오른쪽에 채웁니다. 이로 인해 전체 비트의 길이가 늘어났습니다.
    • 결과적으로 쉬프트 연산 시, 자릿수가 자체적으로 유지되기 보다는, 단순히 지정한 위치만큼 비트가 이동하고 빈 자리에는 0이 채워져 값이 늘어나게 됩니다.
  3. 쉬프트 연산의 원리 요약:

    • 왼쪽으로 비트를 이동할 때마다 비트 크기는 늘어날 수 있으며, 이 경우 10진수 값도 증가합니다. 오른쪽 빈자리는 항상 0으로 채워지기 때문에 기존의 데이터를 보존하지 않습니다.

아래 링크 항목을 참고하시면 더 명확한 정보와 설명을 얻으실 수 있습니다:
- 쉬프트연산 - 쉬프트 연산자의 기본 사용법을 설명하는 게시물입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

김민경님의 프로필 이미지
김민경

작성한 질문수

질문하기