이 튜토리얼에서는 주어진 3개의 숫자로 나누어 떨어지는 가장 큰 n자리 숫자를 찾는 프로그램을 작성할 것입니다.
문제를 해결하는 단계를 살펴보겠습니다.
- n과 함께 3개의 숫자를 초기화합니다.
- 세 숫자의 LCM을 구합니다.
- 가장 큰 수를 n자리로 저장합니다.
- 가장 큰 숫자가 n으로 나누어 떨어지는 경우 반환합니다.
- 또는 위 단계에서 나머지를 뺀 숫자를 확인합니다.
예시
코드를 봅시다.
#include <bits/stdc++.h> using namespace std; int LCM(int x, int y, int z) { int ans = ((x * y) / (__gcd(x, y))); return ((z * ans) / (__gcd(ans, z))); } int findNumber(int n, int x, int y, int z) { int lcm = LCM(x, y, z); int largestNDigitNumber = pow(10, n) - 1; int remainder = largestNDigitNumber % lcm; if (remainder == 0) { return largestNDigitNumber; } largestNDigitNumber -= remainder; if (largestNDigitNumber >= pow(10, n - 1)) { return largestNDigitNumber; } return 0; } int main() { int n = 4, x = 6, y = 7, z = 8; int result = findNumber(n, x, y, z); if (result != 0) { cout << result << endl; }else { cout << "Not possible" << endl; } return 0; }
출력
위의 코드를 실행하면 다음과 같은 결과를 얻을 수 있습니다.
9912
결론
튜토리얼에서 질문이 있는 경우 댓글 섹션에 언급하세요.