首页 > 代码库 > HDU 1695
HDU 1695
http://acm.hdu.edu.cn/showproblem.php?pid=1695
x是[1,b],y是[1,d],求GCD(x,y)=k的对数(x,y无序)
对x,y都除以k,则求GCD(x,y)=1
此时枚举x,问题转化为[1,d]区间内与x互素的数字个数,这个问题是hdu 4135
有一个特殊的地方是x,y无序,对于这点只要保证x始终小于y就可以了
特判k=0
#include <iostream>#include <cstdio>#include <cstring>#include <vector>using namespace std;typedef __int64 ll;vector <int> v;int b,d,k;int main(){ int T; scanf("%d",&T); for(int cas=1;cas<=T;cas++){ scanf("%*d%d%*d%d%d",&b,&d,&k); if(!k){ printf("Case %d: 0\n",cas); continue; } b/=k;d/=k; if(b>d)swap(b,d); int i; ll ans=0; for(i=1;i<=b;i++){ int temp=i; v.clear(); for(int j=2;j*j<=i;j++){ if(i%j==0){ v.push_back(j); while(i%j==0)i/=j; } } if(i>1)v.push_back(i); int m=v.size(); i=temp; ll res=0; for(int j=1;j<(1<<m);j++){ int cnt=0; ll val=1; for(int k=0;k<m;k++){ if(j&(1<<k)){ cnt++; val*=v[k]; } } if(cnt&1)res+=d/val-(i-1)/val; else res-=d/val-(i-1)/val; } ans+=(d-i+1)-res; } printf("Case %d: %I64d\n",cas,ans); } return 0;}
HDU 1695
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。