Rightmost Digit

Rightmost Digit

    Time Limit: 1000 ms 

    Memory Limit: 65535 kB 

    Description

     Given a positive integer N, you should output the rightmost digit of N^N. 

    Input

The input contains several test cases. The first line of the input is a single integer T which is the number of test cases. T test cases follow.
Each test case contains a single positive integer N(1<=N<=1,000,000,000). 
Output

For each test case, you should output the rightmost digit of N^N. 

Sample Input

2

3

4

Sample Output

7

6

Source

我们很容易知道n^n的最后一位数只与n最初的最后一位数有关,且n最后一位数的循环节为如下数组:

 {1, 1, 4, 4, 2, 1, 1, 4, 4, 2},其中第一个对应数字0,最后一个对应数组9,所以很容易得知最后一位数字乘以n次之后的数字为多少。


#include <cstdio>
 
 int main()
 {
 	int f[10] = {1, 1, 4, 4, 2, 1, 1, 4, 4, 2};
 	FILE * fin, * fout;
 	fin = fopen("1.std.in", "r");
 	fout = fopen("1.std.out", "w");
 	int t, n, remainder, num, ans;
 	fscanf(fin, "%d", &t);
 	while ( t-- )
 	{
 		fscanf(fin, "%d", &n);
 		remainder = n % 10;
 		num = n % f[remainder];
 		if ( !num )
 		{
 			num = f[remainder];
 		}
 	    ans = remainder;
 		for ( int i = 1; i < num; i++ )
 		{
 			ans = ( ans * remainder ) %10;
 		}
 		fprintf(fout,    "%d\n", ans);
 	}
 	return 0;
 }
 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值