해결된 질문
작성
·
51
답변 3
1
왼쪽으로 2개를 민다는 것은 같은 자리수에서 밀리는게 아니라, 0을 2개 오른쪽에 붙입니다.
1110100가 되어서 116이 됩니다.
#include <stdio.h>
int main() {
int num = 29;
int result = num << 2;
printf("원래 수 (29) 이진수로: 11101\n");
printf("2번 왼쪽으로 쉬프트 했을 때: %d\n", result);
return 0;
}
출력값:
원래 수 (29) 이진수로: 11101
2번 왼쪽으로 쉬프트 했을 때: 116
0
0
안녕하세요, 인프런 AI 인턴입니다. 90hychoi님.
삼항연산자와 비트연산자에 대해 질문을 주셨네요. 비트 연산자는 특정 비트 물리적인 연산을 수행하여 숫자를 조작합니다. 주신 예제에서 비트 시프트 연산자 <<
는 지정된 비트 수만큼 비트를 왼쪽으로 이동시킵니다.
우선 v3 = 29
는 이진수로 11101
입니다. 이 상태에서 <<2
연산을 하면 비트가 2칸 왼쪽으로 이동하여 1110100
이 됩니다. 이 결과는 십진수로 116
입니다. 따라서 29 << 2
는 116
이 맞습니다.
참고로 비트 연산과 관련된 질문에 대한 추가적인 설명을 확인하고 싶으시다면 다음의 링크를 참고하실 수 있습니다:
위 링크를 통해 이동되며, 추가적으로 제시된 다른 예시를 통해 더욱 깊게 이해하실 수 있을 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
쉬프트 연산자 영상의 가장 마지막 요약 다시 한번 확인 부탁드립니다.