关注
注意到N只有1000 莫比乌斯可快速求得 1-N和1-M gcd为i的个数 枚举就行了 import java.io.*;
import java.util.*;
public class Main {
static int[]prime=new int[100050];
static boolean[]notp=new boolean[100050];
static int[]mu=new int[100050];
public static void main(String[] args) {
FastScanner sc=new FastScanner();
PrintWriter pw=new PrintWriter(System.out);
int N=sc.nextInt();
int n=sc.nextInt();
int m=sc.nextInt();
int p=sc.nextInt();
makeMobius();
int[]A=new int[N+1];
A[1]=p;
for(int i=2;i<=N;i++){
A[i]=(A[i-1]+153)%p;
}
long res=0;
for(int o=1;o<=N;o++){
long min=Math.min(n,m)/o;
long max=Math.max(n,m)/o;
long count1=0;
long count2=0;
for(int i=1;i<=min;i++){
count2+=mu[i]*(min/i)*(max/i);
}
res+=A[o]*count2;
}
pw.println(res);
pw.flush();
}
static int gcd(int a,int b){
return a==0?b:gcd(b%a,a);
}
static void makeMobius() {
Arrays.fill(notp, false);
mu[1] = 1;
int pnum=0;
for (int i = 2; i < 100010; i++) {
if (!notp[i]) {
prime[++pnum] = i; mu[i] = -1;
}
for (int j = 1; prime[j]*i < 100010; j++) {
notp[prime[j]*i] = true;
if (i%prime[j] == 0) {
mu[prime[j]*i] = 0;
break;
}
mu[prime[j]*i] = -mu[i];
}
}
}
}
class FastScanner{
BufferedReader br;
StringTokenizer st;
FastScanner(){
br=new BufferedReader(new InputStreamReader(System.in));
st=new StringTokenizer("");
}
String nextLine(){
String s="";
try {
s=br.readLine();
} catch (IOException e) {
e.printStackTrace();
}
return s;
}
boolean hasNext(){
String s = "";
while(!st.hasMoreTokens()){
s=nextLine();
if(s==null)return false;
st=new StringTokenizer(s);
}
return true;
}
String next(){
String s="";
while(!st.hasMoreTokens()){
s=nextLine();
st=new StringTokenizer(s);
}
return st.nextToken();
}
int nextInt(){
return Integer.valueOf(next());
}
long nextLong(){
return Long.valueOf(next());
}
double nextDouble(){
return Double.valueOf(next());
}
}
查看原帖
点赞 评论
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 哪些公司在招寒假实习? #
13910次浏览 171人参与
# 卷__卷不过你们,只能卷__了 #
10912次浏览 234人参与
# MiniMax求职进展汇总 #
660次浏览 23人参与
# 26年哪些行业会变好/更差 #
17774次浏览 235人参与
# 写论文的崩溃时刻 #
5761次浏览 133人参与
# 去年的flag与今年的小目标 #
9233次浏览 184人参与
# 机械人,你最希望上岸的公司是? #
198006次浏览 1916人参与
# 现在还是0offer,延毕还是备考 #
1256083次浏览 7922人参与
# 有深度的简历长什么样? #
15781次浏览 327人参与
# 你不能接受的企业文化有哪些 #
11043次浏览 157人参与
# 租房前辈的忠告 #
350351次浏览 7445人参与
# 入职第一天 #
9618次浏览 202人参与
# 你都用AI做什么 #
6400次浏览 144人参与
# 最难的技术面是哪家公司? #
62948次浏览 949人参与
# 关于春招你都做了哪些准备? #
122107次浏览 706人参与
# 国企vs私企,你更想去? #
305340次浏览 2486人参与
# 你怎么看待AI面试 #
133300次浏览 745人参与
# 央国企投递记录 #
170259次浏览 1639人参与
# 一人分享一道面试手撕题 #
21583次浏览 767人参与
# 机械人还在等华为开奖吗? #
304963次浏览 1553人参与
# 你在职场上见过哪些“水货”同事 #
29109次浏览 162人参与
