【ZOJ】3881 From the ABC conjecture【暴力容斥】

2024-09-05 14:08

本文主要是介绍【ZOJ】3881 From the ABC conjecture【暴力容斥】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

传送门:【ZOJ】3881 From the ABC conjecture

复杂度大概 O(N0.67) ,我也不会算www,首先转换一下(我们是根据积性函数打表找规律得到的,也可以推出来)使得:

g(N)=pi ϵ N(pia+1)

暴力展开发现贡献为:
h(N)=x=1Ny=1N(xyN and gcd(x,y)=1)x

然后是一个暴力dfs容斥的过程:

ans=x=1Ny=1N(xyN)xk=1Ny=1N(xyN and gcd(x,y)=k)x

=x=1Ny=1N(xyN)xk=1Nky=1N/k2(x/ky/kN/k2 and gcd(x/k,y/k)=1)x/k

可以发现右边是一个原式的递归式,于是我们可以暴力枚举 N 项来暴力,当然计算的值需要记忆化一下。

my  code:

#include <stdio.h>
#include <string.h>
#include <map>
#include <algorithm>
using namespace std ;typedef long long LL ;#define clr( a , x ) memset ( a , x , sizeof a )const int MAXN = 20000005 ;
const int mod = 1e9 + 9 ;
const int v2 = 5e8 + 5 ;map < LL , int > mp ;
map < LL , int > :: iterator it ;
bool vis[MAXN] ;
int dp[MAXN] ;
LL n ;int dfs ( LL n , LL ans = 0 ) {for ( LL i = 1 , j ; i <= n ; i = j + 1 ) {j = min ( n , n / ( n / i ) ) ;LL ni = n / i , x = i + j , y = j - i + 1 ;if ( ni >= mod ) ni %= mod ;if ( x >= mod ) x %= mod ;if ( y >= mod ) y %= mod ;ans += ni * x % mod * y % mod * v2 % mod ;}for ( LL i = 2 ; i * i <= n ; ++ i ) {LL x = n / ( i * i ) ;if ( x < MAXN ) {if ( !vis[x] ) {vis[x] = true ;dp[x] = dfs ( x ) ;}ans -= dp[x] * i % mod ;} else {it = mp.find ( x ) ;if ( it != mp.end () ) ans -= it->second * i % mod ;else {int tmp = dfs ( x ) ;mp.insert ( map < LL , int > :: value_type ( x , tmp ) ) ;ans -= tmp * i % mod ;}}}return ( ans % mod + mod ) % mod ;
}int main () {while ( ~scanf ( "%lld" , &n ) ) printf ( "%d\n" , dfs ( n ) ) ;return 0 ;
}

这篇关于【ZOJ】3881 From the ABC conjecture【暴力容斥】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1139173

相关文章

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

数论ZOJ 2562

题意:给定一个数N,求小于等于N的所有数当中,约数最多的一个数,如果存在多个这样的数,输出其中最大的一个。 分析:反素数定义:对于任何正整数x,其约数的个数记做g(x).例如g(1)=1,g(6)=4.如果某个正整数x满足:对于任意i(0<i<x),都有g(i)<g(x),则称x为反素数。 性质一:一个反素数的质因子必然是从2开始连续的质数。 性质二:p=2^t1*3^t2*5^t3*7

zoj 1721 判断2条线段(完全)相交

给出起点,终点,与一些障碍线段。 求起点到终点的最短路。 枚举2点的距离,然后最短路。 2点可达条件:没有线段与这2点所构成的线段(完全)相交。 const double eps = 1e-8 ;double add(double x , double y){if(fabs(x+y) < eps*(fabs(x) + fabs(y))) return 0 ;return x + y ;

zoj 4624

题目分析:有两排灯,每排n个,每个灯亮的概率为p,每个灯之间互不影响,亮了的灯不再灭,问两排中,每排有大于等于m个灯亮的概率。 设dp[ i ][ j ]为第一排亮了i个灯,第二排亮了j个灯,距离目标状态的期望天数。显然 i >= m ,j >= m时 , dp[ i ][ j ] = 0 。 状态转移 : 第一排亮了a个灯,a 在[ 0 , n - i] 之间,第二排亮了b个灯 , b 在

zoj 3228 ac自动机

给出一个字符串和若干个单词,问这些单词在字符串里面出现了多少次。单词前面为0表示这个单词可重叠出现,1为不可重叠出现。 Sample Input ab 2 0 ab 1 ab abababac 2 0 aba 1 aba abcdefghijklmnopqrstuvwxyz 3 0 abc 1 def 1 jmn Sample Output Case 1 1 1 Case 2

ZOJ Monthly, August 2014小记

最近太忙太忙,只能抽时间写几道简单题。不过我倒是明白要想水平提高不看题解是最好的了。 A  我只能死找规律了,无法证明 int a[50002][2] ;vector< vector<int> > gmax , gmin ;int main(){int n , i , j , k , cmax , cmin ;while(cin>>n){/* g

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu

hdu4059容斥原理

求1-n中与n互质的数的4次方之和 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWrit

计蒜客 Half-consecutive Numbers 暴力打表找规律

The numbers 11, 33, 66, 1010, 1515, 2121, 2828, 3636, 4545 and t_i=\frac{1}{2}i(i+1)t​i​​=​2​​1​​i(i+1), are called half-consecutive. For given NN, find the smallest rr which is no smaller than NN

容斥问题

一、填空题 1.一个班有45个小学生,统计借课外书的情况是:全班学生都借有语文或数学课外书.借语文课外书的有39人,借数学课外书的有32人.语文、数学两种课外书都借的有     人. 3.在1~100的自然数中,是5的倍数或是7的倍数的数有     个. 4.某区100个外语教师懂英语或俄语,其中懂英语的75人,既懂英语又懂俄语的20人,那么懂俄语的教师为     人. 5.六一班