알고리즘 Algorithm/BOJ 백준 (초급~중급)

[BOJ 백준] 최대공약수(2824) C++

섭코딩 2023. 1. 12. 02:14

 

링크 : 

 

문제 설명 : 

더보기

상근이는 학생들에게 두 양의 정수 A와 B의 최대공약수를 계산하는 문제를 내주었다. 그런데, 상근이는 학생들을 골탕먹이기 위해 매우 큰 A와 B를 주었다.

상근이는 N개의 수와 M개의 수를 주었고, N개의 수를 모두 곱하면 A, M개의 수를 모두 곱하면 B가 된다.

이 수가 주어졌을 때, 최대공약수를 구하는 프로그램을 작성하시오.

 

입력 : 

더보기

첫째 줄에 N(1 ≤ N ≤ 1000)이 주어진다. 둘째 줄에는 N개의 양의 정수가 공백으로 구분되어 주어진다. 이 수는 모두 1,000,000,000보다 작고, N개의 수를 곱하면 A가 된다.

셋째 줄에 M(1 ≤ M ≤ 1000)이 주어진다. 넷째 줄에는 M개의 양의 정수가 공백으로 구분되어 주어진다. 이 수는 모두 1,000,000,000보다 작고, M개의 수를 곱하면 B가 된다.

출력 : 

더보기

두 수의 최대공약수를 출력한다. 만약, 9자리보다 길다면, 마지막 9자리만 출력한다. (최대 공약수가 1000012028인 경우에는 000012028을 출력해야 한다)

예제 입력 : 

더보기

3
358572 83391967 82
3
50229961 1091444 8863

예제 출력 : 

더보기

000012028

 

 

접근법 : 

1) 어떻게 풀 것인가?

 

2) 시간복잡도

 

 

3) 공간복잡도

 

 

4) 풀면서 놓쳤던점

 

 

5) 이 문제를 통해 얻어갈 것

 

 

 

C++ 코드 : 

// 최대공약수 2824
#if 1
#pragma warning(disable:4996)
#include <cstdio>

#define MAX (1000+3)
#define INF (1000000000)

using namespace std;

long long gcd(long long a, long long b) {
	// a > b가 되도록 swap(a,b)
	if (b > a) {
		long long  tmp = b;
		b = a;
		a = tmp;
	}

	// 유클리드 호제법
	long long  c;
	while (b) {
		c = a % b;
		a = b;
		b = c;
	}
	return a;
}

int N,M;
int A[MAX];
int B[MAX];

long long ans = 1;

bool isOver;

int main() {

	// 1. 입력
	//freopen("input.txt", "r", stdin);
	
	scanf("%d", &N);
	for (int i = 0; i < N; i++) {
		scanf("%d", &A[i]);
	}

	scanf("%d", &M);
	for (int i = 0; i < M; i++) {
		scanf("%d", &B[i]);
	}

	// 2. 이중 for문
	long long gc;
	for (int i = 0; i < N; i++) {
		for (int j = 0; j < M; j++) {

			gc = gcd(A[i], B[j]);
			
			ans *= gc;
			A[i] /= gc;
			B[j] /= gc;
			
			// 10자리 이상이면 마지막 9자리만 출력
			if (ans >= INF) { 
				ans %= INF;
				isOver = true;
			}

		}
	}

	// 3. 출력방식 조정
	if (isOver) {
		printf("%09lld", ans);
	}	
	else {
		printf("%lld", ans);
	}

	return 0;
}
#endif
반응형