티스토리 뷰
728x90
반응형
목차
분할 정복 단계
문제
자연수 A를 B번 곱한 수를 알고 싶다.
단 구하려는 수가 매우 커질 수 있으므로 이를 C로 나눈 나머지를 구하는 프로그램을 작성하시오.
입력
첫째 줄에 A, B, C가 빈칸을 사이에 두고 순서대로 주어진다.
A, B, C는 모두 2,147,483,647 이하의 자연수이다.
출력
첫째 줄에 A를 B번 곱한 수를 C로 나눈 나머지를 출력한다.
풀이
int 자료형을 넘어서는 결과를 가진 큰 수의 거듭제곱을 빠르게 구하는 문제이다.
분할정복을 이용해 주어진 지수를 반으로 나누며 자기 자신을 재귀호출한 뒤
가장 작은 단위에 도착하면 결과를 합치며 답을 구하는 식으로 구현하면 된다.
문제를 풀고 구현하는 알고리즘은 다음과 같다.
- a, b, c를 입력받는다. 각 변수는 최댓값이 2,147,483,647 이하의 자연수, 즉 int 범위의 자료형이다.
- 재귀함수 pow()를 출력해 그 결괏값을 출력한다. 해당 함수의 작동 방식은 아래와 같다.
- 지수가 1이 될 때까지 거듭제곱의 지수를 반으로 나누어 문제를 분할해 자기 자신을 아래와 같이 호출한다.
long temp = pow(a, exponent / 2, mod);
여기서 temp는 int 범위를 넘어설 수 있기 때문에 long으로 선언해주어야 한다. - 지수가 1이 된 경우 병합과정이 시작된다. 각 단계에서 지수가 짝수인 경우엔 $temp^2 (\mod c)$ 를,
지수가 홀수인 경우엔 $((temp^2 (\mod c)) \times a) (\mod c)$ 를 계산한다.
- 지수가 1이 될 때까지 거듭제곱의 지수를 반으로 나누어 문제를 분할해 자기 자신을 아래와 같이 호출한다.
Java
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Prob1629 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
int a = Integer.parseInt(st.nextToken());
int b = Integer.parseInt(st.nextToken());
int c = Integer.parseInt(st.nextToken());
System.out.println(pow(a, b, c));
}
private static long pow(int a, int exponent, int mod) {
if (exponent == 1) {
return a % mod;
}
long temp = pow(a, exponent / 2, mod);
if (exponent % 2 == 0) {
return (temp * temp) % mod;
} else {
return (((temp * temp) % mod) * a) % mod;
}
}
}
Python
import sys
a, b, c = map(int, sys.stdin.readline().rstrip().split())
def pow(a, exponent, mod):
if exponent == 1:
return a % mod
temp = pow(a, exponent // 2, mod)
if exponent % 2 == 0:
return (temp**2) % mod
else:
return (((temp**2) % mod) * a) % mod
print(pow(a, b, c))
Performance
반응형
'Algorithm > [Java+Python+JavaScript]BackJoon' 카테고리의 다른 글
[Java+Python]10830번, 행렬 제곱 (0) | 2023.06.14 |
---|---|
[Java+Python]2740번, 행렬 곱셈 (0) | 2023.06.12 |
[Java+Python]11401번, 이항 계수 3 (0) | 2023.06.11 |
[Java+Python]1780번, 종이의 개수 (0) | 2023.06.07 |
[Java+Python]1992번, 쿼드 트리 (1) | 2023.06.06 |
[Java+Python]2630번, 색종이 만들기 (2) | 2023.06.05 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 스프링
- 칼이사
- 맛집
- 세계일주
- 세모
- RX100M5
- a6000
- 지지
- java
- 남미
- 스트림
- 유럽여행
- 세계여행
- 면접 준비
- 백준
- 알고리즘
- Algorithm
- 중남미
- 여행
- spring
- Backjoon
- BOJ
- 기술면접
- 자바
- Python
- 리스트
- 야경
- 동적계획법
- 파이썬
- 유럽
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함