关注
注意到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());
}
}
查看原帖
点赞 评论
相关推荐
牛客热帖
正在热议
# 25届秋招总结 #
330463次浏览 3124人参与
# 上班苦还是上学苦呢? #
73142次浏览 654人参与
# 阿里云管培生offer #
37216次浏览 423人参与
# 地方国企笔面经互助 #
4548次浏览 12人参与
# 如果有时光机,你最想去到哪个年纪? #
21964次浏览 410人参与
# 选完offer后,你后悔学本专业吗 #
22000次浏览 159人参与
# 百度开奖 #
185195次浏览 1161人参与
# 我的实习求职记录 #
6071580次浏览 83549人参与
# 如何一边实习一边秋招 #
996985次浏览 12666人参与
# 找工作时遇到的神仙HR #
553616次浏览 3801人参与
# 入职第一天,你准备什么时候下班 #
21656次浏览 144人参与
# 招聘要求与实际实习内容不符怎么办 #
10807次浏览 277人参与
# bilibili求职进展汇总 #
33308次浏览 357人参与
# 许愿池 #
214876次浏览 2535人参与
# 学历or实习经历,哪个更重要 #
54034次浏览 423人参与
# 你今年的平均薪资是多少? #
70994次浏览 345人参与
# 实习工作,你找得还顺利吗? #
247918次浏览 2910人参与
# 通信硬件薪资爆料 #
609396次浏览 5194人参与
# 海康威视求职进展汇总 #
400861次浏览 3408人参与
# 携程求职进展汇总 #
135887次浏览 932人参与
# 正在实习的你,几点下班 #
53424次浏览 396人参与
# 工作两年想退休了 #
53138次浏览 672人参与