题意:有一个老式计算器,只能显示n为数字。有一天,你无聊了,于是输入一个整数k,然后反复平方,直到溢出。每次溢出时,计算器会显示出结果最高的

n位和一个错误标记。然后清除错误标记,继续平方。如果一直这样做下去,能得到的最大数是多少。

题解:简单的推一下,发现其前几位是一个环状结构,及计算器显示出的数将出现循环,应为不管怎么样,数总会出现重复。

这样方法一可以不断模拟,吧结果存入数组中不断找,map去做应该是可以的。

 

但是这里讲一个的算法,即floyd判圈算法,可以大幅降低空间复杂度O(1),其运行时间也下降不少。

可以想象一下,在一个圆形操场上跑,一个孩子跑得比另一个孩子快,那么总会有那么一个时刻会追上,二结果就是记录每次的值即可。

#include<cstdio>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<string>
#include<cstring>

using namespace std;

int t,n;
long long k1,k2,ans;

long long max(long long a,long long b)
{
    return a>b?a:b;
}
long long next(long long x,int k)
{
    x=(long long)x*x;
    long long xx=x,num=0;
    while (xx!=0)
    {
        xx/=10;
        num++;
    }
    for (int i=1;i<=num-k;i++)
    {
        x/=10;
    }
    ans=max(ans,x);
    return x;
}
int main()
{
    scanf("%d",&t);
    while (t--)
    {
        scanf("%d%lld",&n,&k1);
        k2=k1,ans=k1;
        do
        {
            k1=next(k1,n);
            k2=next(k2,n);
            k2=next(k2,n);
        }while(k2!=k1);
        printf("%lld\n",ans);
    }
}