URAL 1698 自守数

简介:

好吧 苟哥总结好了我直接粘了

自守数的定义

 

对于一个k位的自然数n,如果它的平方后的最后k位跟原数相同,那么n就叫做自守数。数学定义表达式为:

 

一位数的自守数有三个,分别为1,5,6。两位数以上的自守数分为A、B两类,A类是以5结尾,B类是以6结尾。

例如,以5结尾的自守数有25,625,90625等;以6结尾的自守数有76、376、9376等。

两类自守数的一个基本性质是:相同位数的两类自守数的和相加等于自守数的位数乘10再加上1,即:

 

5+6=10+1

25+76=100+1

625+376=1000+1

 

关于自守数的两个重要的性质:

(1)一个数为自守数当且仅当它为一个自守数的后缀。

(2)(1除外)n位数的自守数仅有两个(位数包括前导0),优先考虑最高位不为0的时候。

 

一个数为自守数,那么它的所有后缀均为自守数。所以所有位数大于1的自守数的末尾必定为5或6。

对于尾数为5或6这两种自守数,每一种固定长度的自守数至多有1个。

 

 

自守数的计算方法:

 

一个k+1位的自守数F(k+1)可以由F(k)来求得,两类数的计算方法不同。

 

A类:求F(k)的平方,取最后k+1位,若第k+1位是0,则取最后k+2位。

 

例如:

25*25 = 625,得625

6252 = 390625,得90625

8906252 = 793212890625,得2890625

 

B类:

 

求F(k)的平方,取最后k+1位,把最后k+1位的数用10减之代替,若第k+1位是0,则取最后k+2位来减,第k+1位保持为0。

 

例如:

762 = 5776,10-7 = 3,得376
93762 = 87909376,10-9 = 1,得109376

#include <iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
using namespace std;
#define ll long long
ll gcd(ll a,ll b)
{
    return b?gcd(b,a%b):a;
}
ll phi(long long n)
{
    long long rea=n;
    for(int i=2; i*i<=n; i++)
        if(n%i==0)
        {
            rea=rea-rea/i;
            do
                n/=i;
            while(n%i==0);
        }
    if(n>1)rea=rea-rea/n;
    return rea;
}
ll exp_mod(ll a,ll b,ll c)
{
    a%=c;
    ll ans=1;
    while(b)
    {
        if(b&1) ans=ans*a%c;
        b>>=1,a=a*a%c;
    }
    return ans;
}
int main()
{
    ll a,n;
    cin>>a>>n;
    if(gcd(a,n)!=1)
    {
        puts("0");
        return 0;
    }
    ll p=phi(n),l=(ll)sqrt(p*1.0),ans=1e9;
    for(ll i=1; i<=l; i++)
        if(p%i==0)
        {
            if(exp_mod(a,i,n)==1)ans=min(ans,i);
            if(exp_mod(a,p/i,n)==1)ans=min(ans,p/i);
        }
    printf("%I64d\n",ans);
    return 0;
}



目录
相关文章
|
8月前
【每日一题Day221】LC2455可被三整除的偶数的平均值 | 模拟
【每日一题Day221】LC2455可被三整除的偶数的平均值 | 模拟
60 0
|
8月前
|
算法 C语言
(“拨”取数字的典例:N位水仙花数判断及水仙花数变种)
这篇内容介绍了如何判断和生成水仙花数,水仙花数是一个n位数,其各位数字的n次方之和等于该数本身。文章首先回顾了"拨数"的概念,然后通过实例展示了如何判断三位水仙花数,并将其推广到任意位数的水仙花数。作者提供了详细的解题思路和代码示例,强调了解决这类问题时要慢下来,分步骤分析问题。最后,文章还探讨了一个水仙花数的变种问题,即数字拆分后乘积之和等于原数的情况。
345 0
|
8月前
|
C++
【PTA】L1-025 正整数A+B (C++)
【PTA】L1-025 正整数A+B (C++)
142 0
【PTA】L1-025 正整数A+B (C++)
|
8月前
【每日一题Day198】LC1419数青蛙 | 计数
【每日一题Day198】LC1419数青蛙 | 计数
61 0
|
测试技术
PTA1002 写出这个数
PTA1002 写出这个数
63 0
每日一题——“水仙花数”
哈喽大家好,我是保护小周ღ,本期为大家带来的是求“水仙花数”,此水仙花,非彼水仙花,一起来看看把~
137 0
|
算法 C++
【基础算法】几种特殊数(素数、公约数、完全数、亲密数) & C++实现
素数又称为质数,它指在一个大于1的自然数中,除了1和它自身外,没法被其他自然数整除的数。比1大,但不是素数的数称为合数。0和1既不是素数,也不是合数。因为素数的分布没有明显的规律,所以在程序中一般根据素数的定义来判断该数是否为素数。例如哥德巴赫猜想:哥德巴赫通过大量的数据猜测,所有不小于6的偶数,都可以表示为两个奇素数之和。后人将其称之为“1+1”。并且,对于每个不小于9的奇数,都可以表示为三个奇素数之和。
359 0
【基础算法】几种特殊数(素数、公约数、完全数、亲密数) & C++实现
【每日一题Day87】LC1819序列中不同最大公约数的数 | 数学
由于数组中的最大公约数不可能超过子序列的最大值,因此可以枚举所有可能的最大公约数来判断当前的公约数是否有子序列构成。
125 0