| ps | |
|---|---|
| 링크 | acmicpc.net/… | 
| 출처 | BOJ | 
| 문제 번호 | 1351 | 
| 문제명 | 무한 수열 | 
| 레벨 | 골드 5 | 
| 분류 | 
 기초  | 
	
| 시간복잡도 | O(n^K) (K = log2 / log(min(p,q))) | 
| 인풋사이즈 | n<=10^19, p<=10^9, q<=10^9 | 
| 사용한 언어 | Python | 
| 제출기록 | 32416KB / 100ms | 
| 최고기록 | 56ms | 
| 해결날짜 | 2022/06/07 | 
| 태그 | |
"""Solution code for "BOJ 1351. 무한 수열".
- Problem link: https://www.acmicpc.net/problem/1351
- Solution link: http://www.teferi.net/ps/problems/boj/1351
"""
import functools
@functools.cache
def calc(n, p, q):
    if n == 0:
        return 1
    return calc(n // p, p, q) + calc(n // q, p, q)
def main():
    N, P, Q = [int(x) for x in input().split()]
    print(calc(N, P, Q))
if __name__ == '__main__':
    main()