博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj5407: girls
阅读量:7245 次
发布时间:2019-06-29

本文共 1744 字,大约阅读时间需要 5 分钟。

题目描述:

大皮出行,妹子成群,似乎这种事早已经司空见惯了。 大皮最终还是厌倦了这样的⽣活,懂得了节制,他希望每次恰好只有三个妹子陪他。

 大皮有 $n$个妹子,编号为$0$到$n-1$ ,大皮需要次从$n$个中选出三个来愉悦身心。

那么问题来了,有许多妹子为了得到大皮的欢心,产生了冲突,这样的冲突一共有$m$组,为了让自己的出行能清净些,大皮不希望选出的三个妹子,有任何一对存在冲突。

对于每一次选择的三个妹子$i,j,k(i<j<k)$,大皮可以得到的愉悦值为

$A\times i+B\times j+C\times k$

大皮希望你帮他求出所有方案可以得到的愉悦值之和,由于答案太大,请输出答案$mod 2^{64}$

算法标签:三元环计数,容斥

思路:

对于满足的方案容斥一下。

所有方案-有一条边的+有两条边的-有三条边的

以下代码:

#include
#define il inline#define ull unsigned long long#define _(d) while(d(isdigit(ch=getchar())))using namespace std;const int N=2e5+5;bool vis[N];ull A,B,C,ans;int n,m,q[4],in[N];struct node{ int l,r;}t[N];vector
v[N];il int read(){ int x,f=1;char ch; _(!)ch=='-'?f=-1:f;x=ch^48; _()x=(x<<1)+(x<<3)+(ch^48); return f*x;}int main(){ n=read();m=read(); scanf("%llu%llu%llu",&A,&B,&C); for(int i=1;i<=n;i++){ if(i
2)ans+=C*(ull)(1ll*(i-1)*(i-2)/2)*(i-1); } for(int i=1;i<=m;i++){ int x=read()+1,y=read()+1; in[x]++;in[y]++; t[i]=(node){x,y}; if(x>y)swap(x,y); ans-=(ull)(B*(x-1)+C*(y-1))*(ull)(x-1)+A*(ull)(1ll*(x-1)*(x-2)/2ll); ans-=(ull)(A*(x-1)+C*(y-1))*(ull)(y-x-1)+B*(ull)(1ll*(y-x-1)*(x+y-2)/2ll); ans-=(ull)(A*(x-1)+B*(y-1))*(ull)(n-y)+C*(ull)(1ll*(n-y)*(y-1+n)/2ll); v[x].push_back(y);v[y].push_back(x); } for(int i=1;i<=n;i++)sort(v[i].begin(),v[i].end()); for(int x=1;x<=n;x++){ int sz=v[x].size()-1; int num1=0,num2=0; for(int i=0;i<=sz;i++){ int to=v[x][i]; if(to
y))swap(x,y); v[x].push_back(y); } for(int x=1;x<=n;x++){ for(int i=0;i
View Code

 

转载于:https://www.cnblogs.com/Jessie-/p/10427874.html

你可能感兴趣的文章
923A - 你应该看的书
查看>>
storyboard强大利器
查看>>
LAMP论坛搭建
查看>>
我的梦里
查看>>
js中cookie存储以后产生乱码
查看>>
Domino9.0.1FP3下的LDAP、Kerbors详细配置介绍及证书申请颁发
查看>>
HTML5移动游戏平台大战,技术不再主导流量
查看>>
详述Linux配置静态IP、设置DNS和主机名
查看>>
第12课:Spark Streaming源码解读之Executor容错安全性
查看>>
python-高阶函数(函数做返回值)
查看>>
我的友情链接
查看>>
入住51
查看>>
Linux中man命令
查看>>
如何自定义UIBarBtton
查看>>
python学习笔记-Day05-第一部分(再谈装饰器)(递归)
查看>>
BeanShell使用标准Java语法
查看>>
菜鸟学Linux 第046篇笔记 DNS相关概念
查看>>
获取本月的第一天和最后一天
查看>>
backbone.js 框架
查看>>
禁止网站在访问时出现列目录
查看>>