数论 + 公式 - HDU 4335 What is N?

简介: What is N?  Problem's Link:  http://acm.hdu.edu.cn/showproblem.php?pid=4335   Mean:  给你三个数b、P、M,让你求有多少个n满足下式。

What is N? 

Problem's Link:  http://acm.hdu.edu.cn/showproblem.php?pid=4335


 

Mean: 

给你三个数b、P、M,让你求有多少个n满足下式。

analyse:

看到数据被吓到了,没半点思路,后来看了解题报告,方法竟然是暴力!

当然暴力是有条件的。

有这样一个公式:

A^x = A^(x % Phi(C) + Phi(C)) (mod C) (x>=Phi(C))

这个公式的具体证明原来在aekdycoin的百度空间有,但是随着百度空间被转移(百度作死,流失了好多优质的文章==),这篇文章的完整版也流失了。

我们就当这个公式是定理吧!

当n!<Phi(C)时,此时我们暴力解决就可。
 
当n!大于phi(P)的时候,就需要用上面的降幂公式了。
 
方法还是暴力,n!%phi(p)会出现0,这是必然的,至少n>=phi(p)为0,
 
那么(n+1)!%phi(p)也为0,这便出现了重复,转变为n^(phi(p))%p==b的问题了。
 
固定了指数,根据鸽巢原理,余数是循环的,那么只要找出p个的结果,之后通过循环节求解便可以了。
 
Trick:当P为1的时候,b为0,这时候答案是m+1,不过m可能为2^64-1,如果加1的话就会溢出,巨坑。

 

Time complexity: O(N)

 

Source code:

/*
* this code is made by crazyacking
* Verdict: Accepted
* Submission Date: 2015-08-25-23.41
* Time: 0MS
* Memory: 137KB
*/
#include <queue>
#include <cstdio>
#include <set>
#include <string>
#include <stack>
#include <cmath>
#include <climits>
#include <map>
#include <cstdlib>
#include <iostream>
#include <vector>
#include <algorithm>
#include <cstring>
using namespace std;
typedef __int64( LL);
typedef unsigned __int64( ULL);
const double eps( 1e-8);

LL get_eular( LL m)
{
      LL ret = 1;
      for( LL i = 2; i * i <= m; i ++)
            if( m % i == 0)
            {
                  ret *= i - 1;
                  m /= i;
                  while( m % i == 0)
                  {
                        m /= i;
                        ret *= i;
                  }
            }
      if( m > 1) ret *= m - 1;
      return ret;
}

long long Quickpow( long long a , long long b , long long m)
{
      long long ans = 1;
      while(b)
      {
            if(b & 1) { ans =( ans * a) % m ,b --; }
           b /= 2 , a = a * a % m;
      }
      return ans;
}

LL b ,p , m , ring [ 100010 ];
int main()
{
      int t , Cas = 0;
      scanf( "%d" , & t);
      while( t --)
      {
            scanf( "%I64u %I64u %I64u" , &b , &p , & m);
            if(p == 1)
            {
                  if( m == 18446744073709551615ULL)
                        printf( "18446744073709551616 \n ");
                  else
                        printf( "%I64u \n " , m + 1);
                  continue;
            }
            LL i = 0 , phi = get_eular(p ), fac = 1 , ans = 0;
            for( i = 0; i <= m && fac <= phi; i ++)
            {
                  if( Quickpow( i , fac ,p) ==b)
                        ans ++;
                  fac *= i + 1;
            }
            fac = fac % phi;
            for(; i <= m && fac; i ++)
            {
                  if( Quickpow( i , fac + phi ,p) ==b)
                        ans ++;
                  fac =( fac *( i + 1)) % phi;
            }
            if( i <= m)
            {
                  LL cnt = 0;
                  for( int j = 0; j <p; j ++)
                  {
                        ring [ j ] = Quickpow( i + j , phi ,p);
                        if( ring [ j ] ==b)
                              cnt ++;
                  }
                  LL idx =( m - i + 1) /p;
                  ans += cnt * idx;
                  LL remain =( m - i + 1) %p;
                  for( int j = 0; j < remain; j ++)
                        if( ring [ j ] ==b)
                              ans ++;
            }
            printf( "Case #%d: %I64u \n " , ++ Cas , ans);
      }
      return 0;
} /

 

目录
相关文章
HDU7018.Banzhuan(计算几何+贪心)
HDU7018.Banzhuan(计算几何+贪心)
107 0
HDU7018.Banzhuan(计算几何+贪心)
AcWing 658. 一元二次方程公式
AcWing 658. 一元二次方程公式
93 0
AcWing 658. 一元二次方程公式
|
人工智能
唯一分解定理(算术基本定理)详解——hdu5248和lightoj1341
任何一个大于1的自然数 N,如果N不为质数,那么N可以唯一分解成有限个质数的乘积 N=P1a1 P2a2P3a3…Pnan,这里P1<P2<P3…<Pn均为质数,其中指数ai是正整数。这样的分解称为 N 的标准分解式.
312 0
BZOJ 1041: [HAOI2008]圆上的整点【数论,解方程】
1041: [HAOI2008]圆上的整点 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4210  Solved: 1908[Submit][Status][Discuss] Description 求一个给定的圆(x^2+y^2=r^2),在圆周上有多少个点的坐标是整数。
1284 0
|
Java 机器学习/深度学习
UESTC 30 &&HDU 2544最短路【Floyd求解裸题】
最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 65817    Accepted Submission(s): 28794 Problem Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt。
1153 0
|
人工智能 算法
洛谷 P2312 解方程
题目描述 已知多项式方程: $a_0+a_1x+a_2x^2+..+a_nx^n=0$//用LaTex好看多了 求这个方程在[1, m ] 内的整数解(n 和m 均为正整数) 输入输出格式 输入格式:   输入文件名为equation .in。
616 0
|
机器学习/深度学习 算法
数论 + 扩展欧几里得 - SGU 106. The equation
 The equation  Problem's Link   Mean:  给你7个数,a,b,c,x1,x2,y1,y2.求满足a*x+b*y=-c的解x满足x1= lx)    {        ans = min(rx,ry)-ma...
1181 0