问题描述
给一个正整数N,问是否存在N的倍数M,且M的各个位全部由数字8组成,如果存在多个取最小的M;并输出M由几个8组成。
输入格式
一行,一个整数N
输出格式
一行一个整数,表示所求的结果
如果无解,输出0
由题得:M==t*N.
由于M==8*11……1,设n==11……1有k位,则n可以表示为:n==10^(k-1)+10^(k-2)+……+10^0.
因为这是一个等比数列,公比q==10,所以根据等比数列求和公式,n==(10^k-1)/9.
带入最开始的式子M==t*N,得到:M==8*n==8*(10^k-1)/9==t*N,移项,得:8*(10^k-1)==9*t*N.
继续化简,由于8和9*t是已知数,所以对它们约分。设d==gcd(8,9*t),则(8/d)*(10^k-1)==(9*t/d)*N.
由于8/d和9*t/d互质,所以(10^k-1)中含因子9*t/d。令m==9*t/d,则(10^k-1)%m==0,所以10^k%m=&#