HDU 1061 N ^ N 的个位数

博客探讨了在解决HDU 1061问题时遇到的超时问题,由于0^0的特殊情况导致错误。文章推荐使用打表方法来优化计算N^N个位数的效率,并提供了相应的打表代码实现。
摘要由CSDN通过智能技术生成

最原始的方法超时,Wa了几次,原因是 0^0 = 0 ?

#include <iostream>
using namespace std;

int  main()
{
	int t;
	cin >> t;
	while(t--)
	{
		int n; 
		cin >> n;
		int a = n % 10;
		int b = a;
		int mod = 0;
		for(int i = 1; i < n; i++)
		{
			b = (b * a) % 10;
			if(b == a)
			{
				mod = i;
				break;
			}
		}
		if(1 == mod)
		{
			cout << a << endl;
			continue;
		}
		if(mod != 0)
			n =  n % mod + mod;
		b = a;
		for(int i = 1; i < n; i++)
				b = (b * a) % 10;
		cout << b << endl;
	}
	return 0;
}


打表方法肯定是最快,附上打表代码:

#include<stdio.h>  
int main()  
{  
 int n;  
 int a[10][4] = {
  {0},{1},{6,2,4,8},{1,3,9,7},{6,4},{5},{6},{1,7,9,3},{6,8,4,2},{1,9}},d,num;  
 scanf("%d",&num);  
 while
这段代码是解决一个问题的递推算法。问题的描述是:给定一个闭区间 [m, n],其中 m 和 n 是两个正整数,统计该区间内满足特定条件的数字个数。 首先,代码中的 init 函数用于初始化一个二维数组 dp。dp[i][j] 表示第一位为 j 的 i 位数中满足条件的数字数量。初始化时,将 dp[0][0] 设置为 1,表示只有一个位数且为 0,满足条件的数字个数为 1。 然后,通过嵌套循环来计算 dp 数组的其他元素。外层循环遍历位数 i,内层两个循环遍历第 i 位数的可能取值 j 和前一位数的可能取值 k。在遍历过程中,根据特定条件判断,如果满足条件,则将 dp[i][j] 累加上 dp[i-1][k] 的值。 接下来,solve 函数用于计算闭区间 [0, n) 中满足条件的数字个数。首先,将数字 n 拆分成位数,并保存在 digit 数组中。然后,从高位到低位遍历 digit 数组。对于第 i 位数 digit[i],通过嵌套循环来计算满足条件的数字个数。内层循环遍历从 0 到 digit[i]-1 的可能取值 j,根据特定条件判断,如果满足条件,则将答案 ans 加上 dp[i][j] 的值。 在循环过程中,如果第 i 位数 digit[i] 等于 4,则表示以 4 开头的数字后面的数字不满足条件,因此可以直接跳出循环。如果第 i 位数 digit[i] 等于 2 且下一位数 digit[i+1] 等于 6,则表示以 62 开头的数字后面的数字也不满足条件,可以直接跳出循环。 最后,在主函数中,通过调用 init 函数来初始化 dp 数组。然后,通过循环读入输入的 m 和 n 的值,直到 m 和 n 都为 0 时结束循环。在每次循环中,计算闭区间 [m, n] 内满足条件的数字个数,即 solve(m+1) - solve(n),并输出结果。 这段代码利用动态规划的思想,通过递推关系计算满足条件的数字个数,从而高效地解决了给定的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值