넘치게 채우기

[BOJ] 13412 - 서로소 쌍 본문

PS/BOJ

[BOJ] 13412 - 서로소 쌍

riveroverflow 2024. 12. 18. 08:04
728x90
반응형

https://www.acmicpc.net/problem/13412

BOJ - 서로소 쌍

문제 유형: 수학

문제 난이도: Silver II

시간 제한: 1초

메모리 제한: 128MB

 

문제

두 자연수 A, B의 최대공약수를 GCD(A, B)라고 할 때, A와 B가 서로소면 GCD(A, B) = 1이다. 두 자연수 A, B의 최소공배수를 LCM(A, B)라고 할 때, A와 B가 서로소면 LCM(A, B) = A x B이다.

어떤 자연수 N이 서로소인 두 자연수 A, B의 최소공배수라고 할 때, A, B로 가능한 숫자 쌍은 여러 개가 있을 수 있다. 예를 들어 N = 30인 경우 30을 최소공배수로 하는 서로소인 두 자연수로 가능한 숫자 쌍은 (1, 30), (2, 15), (3, 10), (5, 6)의 4가지가 있다.

자연수 N이 주어질 때 N을 최소공배수로 하는 서로소인 자연수 쌍의 개수를 출력하는 프로그램을 작성하시오.

 

입력

첫 번째 줄에 테스트 케이스의 개수를 나타내는 자연수 T가 주어진다. 다음 줄부터 차례로 T개의 테스트 케이스가 주어진다. 각각의 테스트 케이스의 첫째 줄에 100,000,000이하의 자연수 N이 주어진다.

 

출력

각 테스트 케이스의 답을 순서대로 출력한다. 각 테스트 케이스마다 첫 줄에 N을 최소공배수로 하는 서로소인 자연수 쌍의 개수를 한 줄에 하나씩 출력한다.

 

풀이

입력된 수의 약수인 두 수 쌍에 대해서 최대공약수가 1이면 N을 최소공배수로 하는 수이다.

 

코드

C++

#include <bits/stdc++.h>

using namespace std;

int gcd(int a, int b) {
  if (b == 0)
    return a;
  return gcd(b, a % b);
}

void solve() {
  int num;
  cin >> num;
  int root = sqrt(num);
  int ans = 0;
  for (int i = 1; i <= root; ++i) {
    if (num % i == 0 && gcd(num / i, i) == 1) {
      ans++;
    }
  }

  cout << ans << "\n";
}

int main(int argc, char *argv[]) {
  int t;
  cin >> t;
  while (t--) {
    solve();
  }
  return 0;
}
728x90
반응형

'PS > BOJ' 카테고리의 다른 글

[BOJ] 2467 - 용액  (0) 2024.12.20
[BOJ] 2166 - 다각형의 면적  (0) 2024.12.19
[BOJ] 2713 규현이의 사랑을 담은 문자메시지  (0) 2024.12.17
[BOJ] - Choose Your Own Arithmetic  (0) 2024.12.16
[BOJ] 31288 - 캬루  (0) 2024.12.15