mang_dev
맹꽁거리는 개발자
mang_dev
전체 방문자
오늘
어제
  • 분류 전체보기 (185)
    • Frontend (2)
      • Next.js (1)
    • Backend (3)
      • GraphQL (2)
    • Book (1)
      • 기타 (1)
    • Old (177)
      • 알고리즘 퍼즐 (1)
      • 백준 (131)
      • 프로그래머스 (0)
      • Codility (15)
      • LeetCode (7)
      • Codewars (1)
      • Codeforces (0)
      • Django (6)
      • React (2)
      • Naver Map Api (3)
      • Web UI (4)
      • Introduction to Cloud (2)
hELLO · Designed By 정상우.
mang_dev

맹꽁거리는 개발자

백준 9613번 GCD 합 // C++
Old/백준

백준 9613번 GCD 합 // C++

2020. 2. 26. 01:34

문제

 

양의 정수 n개가 주어졌을 때, 가능한 모든 쌍의 GCD의 합을 구하는 프로그램을 작성하시오.

입력

첫째 줄에 테스트 케이스의 개수 t (1 ≤ t ≤ 100)이 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있다. 각 테스트 케이스는 수의 개수 n (1 < n ≤ 100)가 주어지고, 다음에는 n개의 수가 주어진다. 입력으로 주어지는 수는 1000000을 넘지 않는다.

출력

각 테스트 케이스마다 가능한 모든 쌍의 GCD의 합을 출력한다.

 


 

풀이

 

입력받은 모든 수의 최대공약수의 합을 구하는 문제이다.

 

최대공약수는 유클리드 호제법을 사용하여 구하면 된다!

 


 

코드

더보기
#include <iostream>
#include <algorithm>
#include <vector>

using namespace std;

int findGCD(int num1, int num2) {
	if (num1 < num2)
		swap(num1, num2);

	if (num2 == 0)
		return num1;

	return findGCD(num2, num1 % num2);
}

int main() {
	int test_case;

	cin >> test_case;

	for (int t = 0; t < test_case; t++) {
		int n, input;

		cin >> n;
		vector<int> num;
		long long sum = 0;

		for (int i = 0; i < n; i++) {
			cin >> input;

			num.push_back(input);
		}

		for (int i = 0; i < n; i++) {
			for (int j = i + 1; j < n; j++) {
				sum += findGCD(num[i], num[j]);
			}
		}

		cout << sum << "\n";
	}

	return 0;
}
저작자표시 (새창열림)

'Old > 백준' 카테고리의 다른 글

백준 9093번 단어 뒤집기 // C++  (0) 2020.02.26
백준 6588번 골드바흐의 추측 // C++  (0) 2020.02.26
백준 1934번 최소공배수 // C++  (0) 2020.02.26
백준 10026번 적록색약 // C++  (0) 2020.02.26
백준 1389번 케빈 베이컨의 6단계 법칙 // C++  (0) 2020.02.26
    'Old/백준' 카테고리의 다른 글
    • 백준 9093번 단어 뒤집기 // C++
    • 백준 6588번 골드바흐의 추측 // C++
    • 백준 1934번 최소공배수 // C++
    • 백준 10026번 적록색약 // C++
    mang_dev
    mang_dev

    티스토리툴바