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;
}
相关推荐
We་ct15 分钟前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·leetcode·typescript·动态规划
AI科技星17 分钟前
精细结构常数α作为SI 7大基本量纲统一耦合常数的量子几何涌现理论
算法·机器学习·数学建模·数据挖掘·量子计算
笑鸿的学习笔记1 小时前
qt-C++语法笔记之Qt Graphics View 框架中的类型辨析完全指南
c++·笔记·qt
山居秋暝LS1 小时前
安装C++版opencv和opencv_contrib
开发语言·c++·opencv
txzrxz1 小时前
动态规划——背包问题
算法·动态规划
Yingye Zhu(HPXXZYY)1 小时前
洛谷 P15553 [CCPC 2025 哈尔滨站] 液压机
算法
谭欣辰2 小时前
LCS(最长公共子序列)详解
开发语言·c++·算法
m0_629494732 小时前
LeetCode 热题 100-----17.缺失的第一个正数
数据结构·算法·leetcode
Cando学算法2 小时前
鸽笼原理(抽屉原理)
c++·算法·学习方法
Tisfy2 小时前
LeetCode 0796.旋转字符串:暴力模拟
算法·leetcode·题解·模拟·字符串匹配