P1447题解

题目链接

这道题是一道诡异的容斥题。首先我们要确定一个性质,也就是一个点对的gcd就是它的那条线上有几个点。例如点(4,2)到点(0,0)这条线上有2个点。

因此答案其实就是:

但是这样复杂度是不对的。我们可以考虑开一个数组存gcd为i的数对有几个,然后*2-1即可。我们如果不考虑重复的结果就是,但是如果有i的倍数就会有重复,因此我们要像埃氏筛一样把倍数全部给减掉。

最后公式就会变成:

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N=1e5+10;
int n,m,dp[N],ans;
signed main(){
	cin>>n>>m;
	for(int i=max(n,m);i>=1;i--){
		dp[i]=(n/i)*(m/i);
		for(int j=i*2;j<=max(n,m);j+=i) dp[i]-=dp[j];
		ans+=(i*2-1)*dp[i];
	}cout<<ans;
	return 0;
}
相关推荐
ai智能获客_狐狐2 小时前
智能外呼产品架构组成
人工智能·算法·自然语言处理·架构·语音识别
祁同伟.2 小时前
【C++】栈、队列、双端队列、优先级队列、仿函数
c++·容器·stl
Algo-hx3 小时前
数据结构入门 (五):约束即是力量 —— 深入理解栈
数据结构·算法
芒果量化3 小时前
ML4T - 第7章第5节 用线性回归预测股票回报Prediction stock returns with linear regression
算法·回归·线性回归
charlie1145141914 小时前
精读C++20设计模式——结构型设计模式:享元模式
c++·笔记·学习·设计模式·享元模式·c++20
Predestination王瀞潞4 小时前
基础算法(Num012)
c语言·开发语言·算法·排序算法
NiKo_W4 小时前
C++ 反向迭代器模拟实现
开发语言·数据结构·c++·stl
qianmo20214 小时前
基于deepseek学习三角函数相关
学习·算法
YA10JUN4 小时前
C++版搜索与图论算法
c++·算法·图论