[BZOJ5407]girls
也是CF985G。。。
容斥+三元环计数
CF数据太弱啦
vis没赋初值-1竟然过了QAQ
所以又调了我半个小时才搞掉QAQ
数数真难QAQ
记得要写#include<vector>!!!
Dev给加的奇奇怪怪的编译选项会给你自动填补的!!!
QAQ长个记性QAQ
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<vector>
#define ull unsigned long long
#define ll long long
#define inf 20021225
#define N 400010
#define it vector<int>::iterator
using namespace std; int sz[N],deg[N],n,m;
vector<ull> sum[N];
vector<int> ed[N];
struct edge{int to,lt;}e[N];
int in[N],cnt; int vis[N];
void add(int x,int y){e[++cnt].to=y;e[cnt].lt=in[x];in[x]=cnt;}
void go(int x){for(int i=in[x];i;i=e[i].lt) vis[e[i].to]=x;}
ull calc(int x){if(x<) return ; return (ll)x*(x-)/;}
ull up(int l,int r){if(l>r) return ; return (ll)(r+l)*(r-l+)/;}
int main()
{
scanf("%d%d",&n,&m); ull A,B,C,res=;
scanf("%llu%llu%llu",&A,&B,&C); int x,y;
//scanf("%I64d%I64d%I64d",&A,&B,&C); int x,y;
for(int i=;i<=m;i++)
{
scanf("%d%d",&x,&y);
ed[x].push_back(y);
ed[y].push_back(x);
}
//ull edg=(ull)n*(n-1)>>1;
//at least 0
for(int i=;i<n;i++)
res+=A*i*calc(n-i-),
res+=B*i*i*(n-i-),
res+=C*i*calc(i),
sort(ed[i].begin(),ed[i].end()),
sum[i].push_back();
//printf("%llu\n",res);
for(x=;x<n;x++) for(it i=ed[x].begin();i!=ed[x].end();i++)
sz[x]=(*i)>x?sz[x]:sz[x]+,++deg[x],sum[x].push_back(sum[x][deg[x]-]+(*i));
//at least 1
for(x=;x<n;x++) for(it i=ed[x].begin();i!=ed[x].end();i++)
if((*i)<x)
{
y=*i;
//x as B
res-=B*x*(n-x-);
res-=A*y*(n-x-);
res-=C*up(x+,n-);
//x as C
res-=A*up(,y-);
res-=B*y*y;
res-=B*up(y+,x-);
res-=A*y*(x-y->?x-y-:);
res-=C*x*(x-);
}
//printf("%llu\n",res);
//at least 2
//int dig;
//printf("%llu\n",res);
for(x=;x<n;x++) for(int i=;i<=deg[x];i++)
{
//printf("%d %llu\n",x,sum[x][i]);
//x has 2 edges out
y=ed[x][i-];
if(y>x)
{
//x is A
res+=A*x*(deg[x]-i); res+=B*y*(deg[x]-i);
res+=C*(sum[x][deg[x]]-sum[x][i]);
//printf("%d %d %llu\n",x,y,res);
}
else// if(y<x)
{
//x is B
res+=B*x*(deg[x]-sz[x]); res+=A*y*(deg[x]-sz[x]);
res+=C*(sum[x][deg[x]]-sum[x][sz[x]]);
//x is C
res+=C*x*(i-); res+=B*y*(i-);
res+=A*sum[x][i-];
}
}
//printf("%llu\n",res);
//at least 3
/**for(int i=1;i<=n;i++)
{
if(deg[i]<=top)
{
for(int j=0;j<deg[i];j++)
{
for(int k=j+1;k<deg[i];k++)
{
x=i; y=ed[x][j]; z=ed[x][k];
if(x>y) swap(x,y);
if(x>z) swap(x,z);
res-=A*x+B*y+C*z;
}
}
}
else big.push_back(i);
}*/
for(x=;x<n;x++) for(int i=;i<deg[x];i++)
if(deg[ed[x][i]]<deg[x] || (deg[ed[x][i]]==deg[x]&&ed[x][i]<x))
add(x,ed[x][i]);
memset(vis,-,sizeof(vis));
for(x=;x<n;x++)
{
go(x);
for(int i=in[x];i;i=e[i].lt)
{
y=e[i].to;
for(int j=in[y];j;j=e[j].lt)
{
if(vis[e[j].to]==x)
{
int xx=x,yy=y,zz=e[j].to;
if(xx>yy) swap(xx,yy);
if(xx>zz) swap(xx,zz);
if(yy>zz) swap(yy,zz);
res-=A*xx+B*yy+C*zz;
}
}
}
}
printf("%llu\n",res);
//printf("%I64u\n",res);
return ;
}
/**
4 1
2 3 4
1 0
*/
由于这个题调的我太过痛苦 写作业都写不进去
bug列举一下
1.我不会冒泡排序排三个数
2.(0,n-1)看成(1,n)重调系数非常蛋疼
3.初值就是忘了赋
4.系数和值少一个
5.手贱
[BZOJ5407]girls的更多相关文章
- 2013成都网络赛 C We Love MOE Girls(水题)
We Love MOE Girls Time Limit: 1000/500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 123——Appium Girls活动
有感于Ruby Girls和Python Girls,在15年就想组织一次移动测试的妹子活动,框架选择Appium, 从15年夏天开始准备,申请Google的会议室,招募教练,开放报名,审核报名,到正 ...
- HDU 5145 NPY and girls 莫队+逆元
NPY and girls Problem Description NPY's girlfriend blew him out!His honey doesn't love him any more! ...
- 回文串--- Girls' research
HDU 3294 Problem Description One day, sailormoon girls are so delighted that they intend to resear ...
- POJ 1466 Girls and Boys
Girls and Boys Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://poj.org/problem?id=1466 Descripti ...
- 数学+高精度 ZOJ 2313 Chinese Girls' Amusement
题目传送门 /* 杭电一题(ACM_steps 2.2.4)的升级版,使用到高精度: 这次不是简单的猜出来的了,求的是GCD (n, k) == 1 最大的k(1, n/2): 1. 若n是奇数,则k ...
- Girls and Boys
Girls and Boys Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- Acdream Chinese Girls' Amusement
A - Chinese Girls' Amusement Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Jav ...
- HDU----(3294)Girls' research(manacher)
Girls' research Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)T ...
随机推荐
- [Ynoi2012]D1T3
https://www.luogu.org/problemnew/show/P5311 题解 先把点分树建出来. 对于吗,每一个询问\((l,r,x)\),我们对于x要找到它在点分树上最靠上的父亲节点 ...
- LR分析Analysis火车票
一.分析结果 1 研究 Vuser 的行为(F:\JMeter\0Tutorial-SCR\机票预订\机票_analysis-session) 筛选该图,仅查看所有 Vuser 同时运行的时间段 右键 ...
- hdu多校第二场1008(hdu6598) Harmonious Army 最小割
题意: 一个军队有n人,你可以给他们每个人安排战士或者法师的职业,有m对人有组合技,组合技的信息是a,b,c,代表如果这两个人是两个战士,则组合技威力为a,一个战士一个法师,威力为b,其中b=a/4+ ...
- scau 17967 大师姐唱K的固有结界
17967 大师姐唱K的固有结界 该题有题解 时间限制:1000MS 内存限制:65535K 提交次数:41 通过次数:8 收入:107 题型: 编程题 语言: G++;GCC;VC Descr ...
- web storm查看文件结构
菜单栏Navigate -> File Structure https://www.jetbrains.com/help/webstorm/viewing-structure-of-a-sour ...
- python使用中遇到的一些问题
一./usr/bin/ld:cannot find -lxxx错误 例如出现了问题: /usr/bin/ld:cannot find -lssl 其中xxx表示函式库文件名称,如上面的libssl.s ...
- ERROR 1292 (22007): Truncated incorrect DOUBLE value: 'asfsda1'
mysql> UPDATE financial_sales_order SET ASSIGN_TIME = '2018-05-02 00:00:00' where CUSTOMER_ID=354 ...
- 【转载】Stackless Python并发式编程介绍[已校对版]
Stackless Python并发式编程介绍[已校对版] 作者: Grant Olson 电子邮件: olsongt@verizon.net 日期: 2006-07-07 译者: ...
- __I、 __O 、__IO是什么意思?怎么用?
出处:http://www.chuxue123.com/forum.php?mod=viewthread&tid=122&ctid=3 __I. __O .__IO是什么意思?这是ST ...
- CentOS 7安装图形界面
之前公司的服务器都是用的CentOS 的系统,需要安装图形界面的时候我会执行以下命令 yum -y groupinstall "X Window System" "Fon ...