쉬프트연산자 관련 질문입니다
강의 커리큘럼 내 잘 안나오는 문법에서 설명해주신 쉬프트 연산자는
a = 5 // 0101
result = 5 << 1 // 1010
이렇게 2진수의 자릿수는 안바뀌었는데
기출문제 풀이는
v3 = 11101
v3 << 2 = 1110100
으로 왼쪽 자릿수가 지워지지않고 뒤에 00만 더 붙는 형식이어서 헷갈립니다.
2만큼 왼쪽 자릿수를 지우고 미는거라고 이해했었는데 자릿수가 유지되는 기준이 궁금합니다
답변 2
1
미는게 없어지는 것이 아닙니다.
실제로 없어지려면, 우리 현실의 컴퓨터 32비트나 64비트 기준으로 전체를 1로 채우고 밀어야 하는데, 저 예제는 몇 비트 안되어서 해당이 안됩니다.
그냥 2씩 곱하시면 됩니다. (미는 만큼 2의 제곱 수를 곱하면 됨)
0
안녕하세요, 인프런 AI 인턴입니다. 김민경님.
쉬프트 연산자에 대해 이해하기 어려운 점이 있으셨군요. 쉬프트 연산자, 특히 왼쪽 쉬프트 << 연산은 비트의 이동에 따라 값이 달라질 수 있습니다.
쉬프트 연산자의 기본 원리:
- 왼쪽 쉬프트(
<<): 지정한 비트 수만큼 비트를 왼쪽으로 이동합니다. 예를 들어,5를<<1하면 비트가 왼쪽으로 한 칸 이동하여1010(즉 10진수로 10)이 됩니다. 이는5(이진수0101)를 한 칸 왼쪽으로 밀며, 오른쪽 빈자리에0이 채워지는 것입니다.
- 왼쪽 쉬프트(
기출 문제의 이해:
- 주신 예제에서
v3 = 11101이고v3 << 2는1110100이 됩니다. 이 경우11101을(5비트)를2비트왼쪽으로 이동시키며0을 오른쪽에 채웁니다. 이로 인해 전체 비트의 길이가 늘어났습니다.
- 결과적으로 쉬프트 연산 시, 자릿수가 자체적으로 유지되기 보다는, 단순히 지정한 위치만큼 비트가 이동하고 빈 자리에는
0이 채워져 값이 늘어나게 됩니다.
- 주신 예제에서
쉬프트 연산의 원리 요약:
- 왼쪽으로 비트를 이동할 때마다 비트 크기는 늘어날 수 있으며, 이 경우 10진수 값도 증가합니다. 오른쪽 빈자리는 항상
0으로 채워지기 때문에 기존의 데이터를 보존하지 않습니다.
- 왼쪽으로 비트를 이동할 때마다 비트 크기는 늘어날 수 있으며, 이 경우 10진수 값도 증가합니다. 오른쪽 빈자리는 항상
아래 링크 항목을 참고하시면 더 명확한 정보와 설명을 얻으실 수 있습니다:
- 쉬프트연산 - 쉬프트 연산자의 기본 사용법을 설명하는 게시물입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
필기자료 사라졌나요?(실기 일주일만에 안돼서 재도전-_-)
0
51
2
26년 1회 실기 해설 강의
0
68
2
53번 4-1 자료 오류 있는 것 같습니다.
0
73
2
7번문제
0
60
2
C언어 변형문제 9번문제 Pdf 수정요청
0
48
2
메서드 오버드라드
0
51
2
실수
0
46
1
공부 우선순위 우선강의 알려주세요
0
90
1
생성자 호출순서 강의 10번 문제 30분대 질문입니다
0
49
2
25년 2회 기출 5:40 질문입니다.
0
43
2
모의고사1회 3번 파이썬문제
0
75
2
C언어 출제변형 6번 문제
0
50
2
c언어 출제변형 강의 질문
0
32
2
28:40
0
34
2
C : 언어 배열과 문자열 수업자료
0
31
2
파이썬 리스트, 딕셔너리 질문
0
43
2
모의고사 관련 질문 건
1
69
3
자료 내용 오류
0
64
2
정적 변수, 정적 메서드(static) v2
0
51
2
v1.2 와 v0.91 PDF
0
104
1
업캐스팅 (부모형태, 자식생성자)
0
51
2
정보처리산업기사 준비중입니다.
0
74
2
실기 D -6
0
105
2
(기출) 2024년 2회 기출문제 - 이론 포함 22분32초 질문입니다
0
60
3





