HDU 1061 Rightmost Digit

l         Problem-solving ideas:

做这个题首先要知道两个数学规律:

//任何两个数相乘的最低位一定是它们最低位相乘所得结果的最低位

//同一个数连乘结果是具有周期性的,周期不大于10

方法一:利用以上两个规律构造出乘积周期性的解法。

方法二:直接利用快速幂

l         Source code:

方法一:

#include<stdio.h>

#include<math.h>

 

int main()

{

       int ncase;

       int a,t,rst,k,m;

       int record[10];

       int i;

       

       scanf("%d",&ncase);

       while(ncase--)

       {

              scanf("%d",&a);

              k=a%10;

              t=k;

              record[0]=t;

              for(i=1;i<10;i++)

              {

                     t=(k*t)%10;

                     record[i]=t;

                     if(k == t)

                     {

                            m=i;

                            break;

                     }

              }

 

              printf("%d\n",record[(a-1)%m]);

       }

       return 0;

}

 

方法二:

#include<stdio.h>

 

int pow(int x, unsigned int n)

{

    int rst = 1;

while (n > 0)

{

        if (n & 1)        // n & 1等价于(n % 2) == 1

            rst = (rst*x)%10;

        x = (x*x)%10;

        n >>= 1;        // n >>= 1等价于n /= 2

    }

   return rst;

}

 

int main()

{

       int ncase;

       int a;

 

       scanf("%d",&ncase);

       while(ncase--)

       {

              scanf("%d",&a);

 

              printf("%d\n",pow(a%10,a));

       }

       return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值