QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#306309#8017. 计算_set_Compile Error//C++141.5kb2024-01-16 17:12:542024-01-16 17:12:55

Judging History

你现在查看的是最新测评结果

  • [2024-01-16 17:12:55]
  • 评测
  • [2024-01-16 17:12:54]
  • 提交

answer

// test if L<=R
#include <cstdio>
#include <algorithm>
using namespace std;
int read(){
	char c=getchar();int x=0;
	while(c<48||c>57) c=getchar();
	do x=(x<<1)+(x<<3)+(c^48),c=getchar();
	while(c>=48&&c<=57);
	return x;
}
const int P=998244353;
typedef long long ll;
int qp(int a,int b=P-2){
	int res=1;
	while(b){
		if(b&1) res=(ll)res*a%P;
		a=(ll)a*a%P;b>>=1;
	}
	return res;
}
ll getpw(ll a,int b){
	ll res=1;
	while(b){
		if(b&1){
			res*=a;
			if(b==1) return res;
		}
		a*=a;b>>=1;
	}
	return res;
}
const int N=10000003;
const int E=1e7;
int phi[N];
int pr[N],rk;
bool vis[N];
void solve(){
	int m=read();
	int a=read(),b=read(),c=read(),d=read();
	int l=__gcd(a,b),r=__gcd(c,d);
	ll L=getpw(m,l),R=getpw(m,r);
	if(L==R){puts("1");return;}
	//if(L>R){puts("6710912");return;}
	assert(L<R);
	ll T=R/m-L/m;
	int mm=m>>__builtin_ctz(m);
	int cur=0,pp=qp(2,T%(P-1)*(m&-m)%(P-1));
	auto proc=[&](int x){cur=(cur+(ll)qp(pp,x)*phi[mm/x])%P;};
	for(int i=1;i*i<=mm;++i)
		if(mm%i==0){
			proc(i);
			if(i*i<mm) proc(mm/i);
		}
	cur=(ll)cur*qp(m)%P;
	printf("%d\n",cur);
}
int main(){
	// freopen("calculate.in","r",stdin);
	// freopen("calculate.out","w",stdout);
	phi[1]=1;
	for(int i=2;i<=E;++i){
		if(!vis[i]){pr[++rk]=i;phi[i]=i-1;}
		for(int j=1;j<=rk;++j){
			int cur=i*pr[j];
			if(cur>E) break;
			vis[cur]=1;
			if(i%pr[j]) phi[cur]=phi[i]*(pr[j]-1);
			else{phi[cur]=phi[i]*pr[j];break;}
		}
	}
	int tc=read();
	while(tc--) solve();
	return 0;
}

详细

answer.code: In function ‘void solve()’:
answer.code:45:9: error: ‘assert’ was not declared in this scope
   45 |         assert(L<R);
      |         ^~~~~~
answer.code:4:1: note: ‘assert’ is defined in header ‘<cassert>’; did you forget to ‘#include <cassert>’?
    3 | #include <algorithm>
  +++ |+#include <cassert>
    4 | using namespace std;