C++ 숫자 골라내기 - CodeGround

Updated:

1번 숫자 골라내기


문제


초등학교교 학생인 정우와 석환이는 최근 학교에서 두 이진수의 XOR 연산에 대해 배웠다.
둘은 매우 영특한 학생이라 새로 배운 연산을 갖고 이리저리 장난치기 시작했다.
다만 석환이는 정우에게 일을 시키는 것을 좋아하는지라 다음과 같은 제안을 했다.

“내가 N개의 10진수를 주면, 등장하는 숫자들 중 홀수번만 나타나는 숫자들을 모두 XOR한 결과를 구해줘.”

예를 들어 ‘2, 5, 3, 3’ 이 주어질 경우, ‘2’와’5’는 1번(홀수 번) 나타나고 ‘3’ 은 2번 (짝수 번) 나타나므로 홀수 번 나타난 ‘2’ 와 ‘5’를 XOR 한 결과를 구해야 하고, ‘2, 5, 3, 3, 2, 4, 5, 3’ 이 주어질 경우 ‘2’ 와 ‘5’ 는 2번 나타나고, ‘3’ 은 3번, ‘4’ 는 1번 나타나므로 홀수 번 나타난 ‘3’ 과 ‘4’를 XOR 한 결과를 구해야 한다.

정우는 제안을 수락했지만, 가면 갈수록 매번 XOR 연산을 수행하는 일에 지치고 있다.
정우를 도와서 주어 진 문제를 해결하는 프로그램을 작성하라.

입력


입력 파일에는 여러 테스트 케이스가 포함될 수 있다.
파일의 첫째 줄에 케이스의 개수를 나타내는 자연수 T 가 주어지고, 이후 차례로 T 개의 테스트 케이스가 주어진다. ( 1≤T≤20 ) 각각의 테스트 케이스 첫 번째 줄에는 석환이가 말한 숫자 N ( N 은 3,000,000 이하의 자연수)이 주어진다.
테스트 케이스의 둘째 줄에는 N개의 숫자들이 공백(빈칸)을 사이에 두고 주어진다.
각 숫자는 32bit 정수형 변수에 담을 수 있는 음이 아닌 정수이다.

1
4
2 5 3 3

출력


각 테스트 케이스의 답을 순서대로 표준출력으로 출력하여야 하며, 각 테스트 케이스마다 첫 줄에는 “Case #T”를 출력하여야 한다. 이때 T는 케이스의 번호이다.
그 다음 줄에는 주어진 숫자들 중에서 ‘홀수’ 번만 나타나는 숫자들을 모두 XOR 한 결과를 출력한다.

Case #1
7

정답


#include <iostream>
#include <algorithm>
#include <vector>

using namespace std;

int main(void)
{
	int T = 0, test_case = 0;
	int number = 0, N = 0, i = 0;

	cin >> T;

	for (test_case = 0; test_case < T; test_case++)
	{
		int Answer = 0;

		cin >> N;

		for (i = 0; i < N; i++)
		{
			cin >> number;
			Answer ^= number;  // XOR 연산
		}

		cout << "Case #" << test_case+1 << "\n" << Answer << endl;
	}

	return 0;
}

Leave a comment