K尾数相等数

从键盘输入一个自然数K(k>1),若存在自然数M,N(M>N),使得K^M和K^N均大于或等于1000,且他们的末尾3位数相等,则称M和N是一对“K尾数相等数”。编程输出M+N值最小的K尾相等数。
sample input
2
outputfor the input
120

 

因为只需要最末3位相同就相同,所以 

 

#include < stdio.h >
int  main()
{
    
// freopen("in.txt","r",stdin);
    
// freopen("out.txt","w",stdout);
     long   int  k,i;
    
while (scanf( " %d " , & k),k){
        
long   int  a[ 1000 ] = { 0 },t,flag = 0 ;
        
if (k >= 1000 ) {k %= 1000 ;a[k] ++ ;flag = 1 ;}
        
for (t = k,i = 2 ;;i ++ ){
            k
= t * k;
            
if (flag == 1 || k >= 1000 ){
                k
%= 1000 ;
                a[k]
+= i;
                
if (a[k] > i)
                    
break ;
            }
        }
        printf(
" %d " ,a[k]);
        
    }
    
return   0 ;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值