[C언어 코드업 문제풀이] CodeUp 1062 : [기초-비트단위논리연산] 비트단위로 XOR 하여 출력하기(설명)

코드업 1062번 비트단위로 XOR 하여 출력하기 문제 풀이 해답입니다.

1. 문제 설명

 

입력된 정수 두 개를 비트단위로 xor 연산한 후 그 결과를 정수로 출력해보자.
비트단위(bitwise) 연산자 ^(xor, circumflex/caret, 서컴플렉스/카릿)를 사용하면 된다.

** 주의 ^은 수학식에서 거듭제곱(power)을 나타내는 기호와 모양은 같지만,
C언어에서는 전혀 다른 배타적 논리합(xor, 서로 다를 때 1)의 의미를 가진다.

** 비트단위(bitwise) 연산자는,
~(bitwise not), &(bitwise and), |(bitwise or), ^(bitwise xor),
<<(bitwise left shift), >>(bitwise right shift)
가 있다.

예를 들어 3과 5가 입력되었을 때를 살펴보면
3       : 00000000 00000000 00000000 00000011
5       : 00000000 00000000 00000000 00000101
3 ^ 5 : 00000000 00000000 00000000 00000110
이 된다.
이러한 비트단위 연산은 빠른 계산이 필요한 그래픽처리에서도 효과적으로 사용된다.

구체적으로 설명하자면,
두 장의 이미지가 겹쳐졌을 때 색이 서로 다른 부분만 처리할 수 있다.
배경이 되는 그림과 배경 위에서 움직이는 그림이 있을 때,
두 그림에서 차이만 골라내 배경 위에서 움직이는 그림의 색으로 바꿔주면
전체 그림을 구성하는 모든 점들의 색을 다시 계산해 입히지 않고
보다 효과적으로 그림을 처리할 수 있게 되는 것이다.
비행기 슈팅게임 등을 상상해보면 된다. 

 

2. 입력

 

2개의 정수가 공백을 두고 입력된다.
-2147483648 ~ +2147483647 

 

3. 출력

 

두 정수를 비트단위(bitwise)로 xor 계산을 수행한 결과를 10진수로 출력한다. 

 

4. 입력 예시

 

3 5

 

5. 출력 예시

 

6

 

6. 문제 풀이

 

#include <stdio.h>
 
 
int main (void)
{
    int num1,num2,result;
 
    
    scanf("%d %d"&num1 , &num2);
    result = num1 ^ num2;
    
    printf("%d",result);
 
    
    return 0;
}
 

 

서로 다를때 1을 출력하는 배타적 논리합(XOR)를 이용하는 문제입니다.

기호는 ^ 를 사용하며

 

0011 ^ 0101 의 경우 서로 다른비트만 1이 됩니다.

 

0110 -> 6이란 결과를 얻을 수 있습니다.

댓글()