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;
}
相关推荐
John_Rey6 小时前
API 设计哲学:构建健壮、易用且符合惯用语的 Rust 库
网络·算法·rust
愿没error的x6 小时前
动态规划、贪心算法与分治算法:深入解析与比较
算法·贪心算法·动态规划
NONE-C6 小时前
动手学强化学习 第6章 Dyna-Q 算法
算法
Kimser7 小时前
QT C++ QWebEngine与Web JS之间通信
javascript·c++·qt
QT 小鲜肉7 小时前
【QT/C++】Qt样式设置之CSS知识(系统性概括)
linux·开发语言·css·c++·笔记·qt
惊讶的猫7 小时前
面向无监督行人重识别的摄像头偏差消除学习
人工智能·算法·机器学习
Elias不吃糖7 小时前
NebulaChat 框架学习笔记:深入理解 Reactor 与多线程同步机制
linux·c++·笔记·多线程
深度学习机器7 小时前
RAG Chunking 2.0:提升文档分块效果的一些经验
人工智能·算法·llm
努力学习的小全全7 小时前
【CCF-CSP】05-01数列分段
数据结构·算法·ccf-csp
转基因7 小时前
命名空间与匿名空间
c++