O gcd 板子

Posted uid001

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了O gcd 板子相关的知识,希望对你有一定的参考价值。

const int N = 2e5+10;
const int M = 500;
int cnt, p[N], _gcd[M][M];
int v[N][3],vis[N];
int gcd(int x, int y) 
	int g = 1;
	REP(i,0,2) 
		int tmp;
		if (v[x][i]>=M) 
			if (y%v[x][i]==0) tmp = v[x][i];
			else tmp = 1;
		
		else tmp = _gcd[y%v[x][i]][v[x][i]];
		y /= tmp, g *= tmp;
	
	return g;


void init() 
	v[1][0] = v[1][1] = v[1][2] = 1;
	REP(i,2,N-1) 
		if (!vis[i]) p[++cnt]=i,v[i][0]=v[i][1]=1,v[i][2]=i;
		for (int j=1; j<=cnt&&i*p[j]<N; ++j) 
			vis[i*p[j]] = 1;
			int *A = v[i*p[j]], *B = v[i];
			A[0] = B[0]*p[j], A[1] = B[1], A[2] = B[2];
			if (A[0]>A[1]) swap(A[0],A[1]);
			if (A[1]>A[2]) swap(A[1],A[2]);
			if (i%p[j]==0) break;
		
	
	REP(i,1,M-1) 
		_gcd[i][0] = _gcd[0][i] = i;
		REP(j,1,i) _gcd[i][j]=_gcd[j][i]=_gcd[i%j][j];
	

 

 

以上是关于O gcd 板子的主要内容,如果未能解决你的问题,请参考以下文章

NOIP的板子们 (未完待续)

板子数论集合

线段树板子

数论板子大总结

[板子]最小生成树

二分图板子