codeforces 1009D Relatively Prime Graph【欧拉函数】
题目:戳这里
题意:要求构成有n个点,m条边的无向图,满足每条边上的两点互质。
解题思路:
显然1~n这n个点能构成边的条数,就是2~n欧拉函数之和(x的欧拉函数值代表小于x且与x互质的数的个数。
因此m>n-1 && m <= sum成立则可以构成无向图。
接着求出1e5以内的欧拉函数,求和可以发现前1000项的欧拉值就已经远远大于1e5。
所以m条边直接两层循环暴力即可。
附本人代码:
- 1 #include <bits/stdc++.h>
- 2 typedef long long ll;
- 3 const int maxn = 1e5+10;
- 4 const ll inf = 1e18;
- 5 const ll mod = 1e9+7;
- 6 using namespace std;
- 7 ll cnt[maxn];
- 8 ll euler[maxn];
- 9 void geteuler() {
- 10 memset(euler, 0, sizeof(euler));
- 11 euler[1] = 1;
- 12 for(ll i = 2; i < maxn; ++i) {
- 13 if(!euler[i]) {
- 14 for(ll j = i; j < maxn; j+=i) {
- 15 if(!euler[j]) euler[j] = j;
- 16 euler[j] = euler[j]/i * (i - 1ll);
- 17 }
- 18 }
- 19 }
- 20 }
- 21 ll gcd(ll a, ll b) {return b?gcd(b,a%b):a;}
- 22 int main(){
- 23 ll n, m;
- 24 ll sum = 0;
- 25 scanf("%lld %lld", &n, &m);
- 26 geteuler();
- 27 for(ll i = 2; i <= n; ++i) {
- 28 sum += euler[i];
- 29 }
- 30
- 31 // printf("%lld\n", sum);
- 32 if(sum < m || m < n - 1) {
- 33 puts("Impossible");
- 34 return 0;
- 35 }
- 36 puts("Possible");
- 37 for(ll i = 1; i <= n; ++i) {
- 38 for(ll j = i + 1; j <= n; ++j) {
- 39 if(gcd(i,j)==1) {
- 40 printf("%lld %lld\n", i, j);
- 41 --m;
- 42 if(!m) return 0;
- 43 }
- 44 }
- 45 }
- 46 return 0;
- 47 }
codeforces 1009D Relatively Prime Graph【欧拉函数】的更多相关文章
- Codeforces 906D Power Tower(欧拉函数 + 欧拉公式)
题目链接 Power Tower 题意 给定一个序列,每次给定$l, r$ 求$w_{l}^{w_{l+1}^{w_{l+2}^{...^{w_{r}}}}}$ 对m取模的值 根据这个公式 每次 ...
- CodeForces - 1009D Relatively Prime Graph
题面在这里! 直接暴力找点对就行了,可以证明gcd=1是比较密集的,所以复杂度略大于 O(N log N) #include<bits/stdc++.h> #define ll long ...
- Codeforces 1114F Please, another Queries on Array? [线段树,欧拉函数]
Codeforces 洛谷:咕咕咕 CF少有的大数据结构题. 思路 考虑一些欧拉函数的性质: \[ \varphi(p)=p-1\\ \varphi(p^k)=p^{k-1}\times (p-1)= ...
- Codeforces Round #538 (Div. 2) F 欧拉函数 + 区间修改线段树
https://codeforces.com/contest/1114/problem/F 欧拉函数 + 区间更新线段树 题意 对一个序列(n<=4e5,a[i]<=300)两种操作: 1 ...
- CodeForces - 645F:Cowslip Collections (组合数&&欧拉函数)
In an attempt to make peace with the Mischievious Mess Makers, Bessie and Farmer John are planning t ...
- Codeforces 871D Paths (欧拉函数 + 结论)
题目链接 Round #440 Div 1 Problem D 题意 把每个数看成一个点,如果$gcd(x, y) \neq 1$,则在$x$和$y$之间连一条长度为$1$的无向边. ...
- Codeforces 1114F(欧拉函数、线段树)
AC通道 要点 欧拉函数对于素数有一些性质,考虑将输入数据唯一分解后进行素数下的处理. 对于素数\(p\)有:\(\phi(p^k)=p^{k-1}*(p-1)=p^k*\frac{p-1}{p}\) ...
- Please, another Queries on Array?(Codeforces Round #538 (Div. 2)F+线段树+欧拉函数+bitset)
题目链接 传送门 题面 思路 设\(x=\prod\limits_{i=l}^{r}a_i\)=\(\prod\limits_{i=1}^{n}p_i^{c_i}\) 由欧拉函数是积性函数得: \[ ...
- Codeforces 776E: The Holmes Children (数论 欧拉函数)
题目链接 先看题目中给的函数f(n)和g(n) 对于f(n),若自然数对(x,y)满足 x+y=n,且gcd(x,y)=1,则这样的数对对数为f(n) 证明f(n)=phi(n) 设有命题 对任意自然 ...
随机推荐
- vue-cli3x4x修改本地端口port
一.推荐方法 "scripts": { "serve": "vue-cli-service serve --port 3000", &quo ...
- 解决安装mysql动态库libstdc++.so.6、libc.so.6版本过低问题
初始化mysql报错: ./bin/mysqld: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.15' not found (required by ...
- OpenStack使用OVN
1. Controller节点 1.1 安装 OVS和OVN 安装 Python3.7: yum -y groupinstall "Development tools" yum - ...
- 一文搞定全场景K3s离线安装
作者简介 王海龙,Rancher中国社区技术经理,负责Rancher中国技术社区的维护和运营.拥有6年的云计算领域经验,经历了OpenStack到Kubernetes的技术变革,无论底层操作系统Lin ...
- SuperUpdate.sh 一键更换Linux软件源脚本
一.前言 有时候会遇到 Linux 的源更新速度非常的缓慢,特别是在国内使用默认的源,因为国内的网络环境,经常会出现无法更新,更新缓慢的情况.在这种情况下,更换一个更适合或者说更近,更快的软件源,会为 ...
- Property attribute.
class property(object): """ Property attribute. fget function to be used for getting ...
- VMware 虚拟机逃逸漏洞
所谓虚拟机逃逸(Escape Exploit),指的是突破虚拟机的限制,实现与宿主机操作系统交互的一个过程,攻击者可以通过虚拟机逃逸感染宿主机或者在宿主机上运行恶意软件. 针对 VMware 的虚拟机 ...
- Quartz 定时任务调度
一.在Quartz.NET中quartz.properties的配置文件,忽略不修改,考虑下面: var props = new NameValueCollection { { "quart ...
- 题解 P3833 【[SHOI2012]魔法树】
题目 直通车 很显然这是个树刨的板子,树上链查询和子树查询 注意: 1.这个点的树根为 0 而不是 1 所以注意读图时点标号 +1 就解决了 2.注意数据范围\(2^{32}\) 然后板子就能过了 n ...
- POSTGIS
https://blog.csdn.net/qq_35732147/article/details/85256640 官方文档:http://www.postgis.net/docs/ST_Buffe ...