描述:
N<k 时,root(N,k) = N,否则,root(N,k) = root(N',k)。N’为 N 的 k 进制表示的各位数字之和。 输入 x,y,k,输出 root(x^y,k)的值 (这里^为乘方,不是异或),2=<k<=16,0<x,y<2000000000,有一半的测试点里 x^y 会溢出 int 的范围(>=2000000000)
输入描述: 每组测试数据包括一行,x(0<x<2000000000), y(0<y<2000000000), k(2<=k<=16)
输出描述: 输入可能有多组数据,对于每一组数据,root(x^y, k)的值
示例
输入:
4 4 10
输出:
4解析:
依题意可知,N’为 N 的 k 进制表示的各个位数之和。
首先用 k 进制来表示$N=a_0+a_1k+a_2k^2+…+a_nk^n$,那么$N'=a_0+a_1+a_2+…+a_n$
于是就有$N-N'=a_1(k-1)+a_2(k^2-1)+…+a_n(k^n-1)$,由于$k-1,..,k^n-1$都包含$k-1$因子
故$(N-N')$ % $(k-1)=0$
于是可以如下推导:
$(N'-N'')$ % $(k-1)=0$
$(N^{(i-1)}-N^{(i)})$ % $(k-1)=0$
由此可得前 $i$ 项和为 $(N-N^{(i)})$ % $(k-1)=0$
移项后得到$N^{(i)}=N$ % $(k-1)$
依题意要求,即$N^{(i)}=x^y$%$(k-1)$
|
|