結果
| 問題 | No.581 XOR | 
| コンテスト | |
| ユーザー |  aaa | 
| 提出日時 | 2018-10-01 17:08:14 | 
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 2 ms / 2,000 ms | 
| コード長 | 1,040 bytes | 
| コンパイル時間 | 828 ms | 
| コンパイル使用メモリ | 95,140 KB | 
| 実行使用メモリ | 6,820 KB | 
| 最終ジャッジ日時 | 2024-10-12 09:51:24 | 
| 合計ジャッジ時間 | 1,343 ms | 
| ジャッジサーバーID (参考情報) | judge3 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 1 | 
| other | AC * 8 | 
ソースコード
#include <stdio.h>
#include <algorithm>
#include <iostream>
#include <string>
#include <vector>
#include <functional>
#include <map>
#include <iomanip>
#include <math.h> 
#include <stack>
#include <queue>
#include <bitset>
#include <cstdlib>
#include <tuple>
#include <cctype>
#include <ctype.h>
#include <set>
#include <sstream>
using namespace std;
int main() {
	int i, j, k;   
	long long a, c;
	cin >> a >> c;
	bitset<50>aa(a);
	bitset<50>cc(c);
	//cout << aa << endl;
	string ast = aa.to_string();
	string cst = cc.to_string();
	string bst;
	for (i = 0; i < ast.length(); i++) {
		if (ast[i] == '1' && cst[i] == '0') {
			bst += '1';
		}
		else if (ast[i] == '0' && cst[i] == '0') {
			bst += '0';
		}
		else if (ast[i] == '1' && cst[i] == '1') {
			bst += '0';
		}
		else if (ast[i] == '0' && cst[i] == '1') {
			bst += '1';
		}
	}
	long long b = 0;
	long long keta = 1;
	for (i = bst.length() - 1; i >= 0; i--) {
		b += ((int)bst[i] - 48) * keta;
		keta *= 2;
	}
	cout << b << endl;
	getchar();
	getchar();
	return 0;
}
            
            
            
        