#include #include // 数値を0/1の組み合わせの配列にセット // プラスを使えないのでループは逆から void setBinVal( int n, long* buf ){ int i; for( i = 32; i >= 0; i--){ if( n == 0 ){ break; } if( n % 2 == 0){ buf[32-i] = 0; } else{ buf[32-i] = 1; } n = n / 2; } return; } int main(void){ long a, b; long c; scanf( "%ld %ld", &a, &b ); long abuf[33]; long bbuf[33]; long cbuf[33]; char buf[34]; int i = 0; int kuriagari = 0; int idx = 0; buf[33] = '\0'; for( i = 32; i >= 0; i--){ abuf[32-i] = 0; bbuf[32-i] = 0; cbuf[32-i] = 0; } // 0/1を組み合わせて2進数を表現 setBinVal( a, abuf ); setBinVal( b, bbuf ); // 1と0の組み合わせパターンで演算の代わりとする for( i = 32; i >= 0; i--){ //操作したい位置 idx = 32 - i; if( (abuf[idx] == 0) && (bbuf[idx] == 0) ){ cbuf[idx] = kuriagari; kuriagari = 0; }else if( abuf[idx] == 1 && bbuf[idx] == 1 ){ cbuf[idx] = kuriagari; kuriagari = 1; }else{ if( kuriagari == 1 ){ cbuf[idx] = 0; kuriagari = 1; }else{ cbuf[idx] = 1; kuriagari = 0; } } } // 2進数文字列に for( i = 32; i >= 0; i--){ buf[i] = ( cbuf[32-i] == 1 ) ? '1' : '0'; } // 10進数数値に c = strtol( buf, NULL, 2); printf( "%d\n", c); return 0; }