#网络流,树状数组#JZOJ 4020 Revolution with JZOJ 4018 Magic
CF297E Mystic Carvings=JZOJ 4018 Magic
JZOJ 4020 Revolution
题目
有一个\(n*m(n,m\leq 20)\)的网格图
这格子有收益当且仅当上下左右都被投资或者自身被投资,
问最多能赚多少
分析
一看就是最小割,但是实际建图比较难搞,因为还有相邻这种建图
那可以奇偶性建图,收益\((i,j)\)连源点\((i+j=even)\),收益\((x,y)\)连汇点\(x+y=odd\)
投资\((i',j')\)连\((i,j)\),投资\((x',y')\)连\((x,y)\),相邻因为两种点都有可能,所以要交错连接一条无限大的边
代码
#include <cstdio>
#include <cctype>
#include <queue>
#define rr register
#define ide(i,j) ((i-1)*m+j)
using namespace std;
const int dx[4]={0,0,1,-1},dy[4]={1,-1,0,0};
const int inf=707406378; struct node{int y,w,next;}e[10011];
int ls[821],dis[821],cost[21][21],reward[21][21],n,m,k=1,s,t,ans;
inline void add(int x,int y,int w){
e[++k]=(node){y,w,ls[x]}; ls[x]=k;
e[++k]=(node){x,0,ls[y]}; ls[y]=k;
}
inline signed bfs(int s){
for (rr int i=1;i<=t;++i) dis[i]=0;
rr queue<int>q; q.push(s); dis[s]=1;
while (q.size()){
rr int x=q.front(); q.pop();
for (rr int i=ls[x];i;i=e[i].next)
if (e[i].w>0&&!dis[e[i].y]){
dis[e[i].y]=dis[x]+1;
if (e[i].y==t) return 1;
q.push(e[i].y);
}
}
return 0;
}
inline signed dfs(int x,int now){
if (x==t||!now) return now;
rr int rest=0,f;
for (rr int i=ls[x];i;i=e[i].next)
if (e[i].w>0&&dis[e[i].y]==dis[x]+1){
rest+=(f=dfs(e[i].y,min(now-rest,e[i].w)));
e[i].w-=f; e[i^1].w+=f;
if (now==rest) return rest;
}
if (!rest) dis[x]=0;
return rest;
}
signed main(){
scanf("%d%d",&n,&m),s=n*m*2+1,t=s+1;
for (rr int i=1;i<=n;++i)
for (rr int j=1;j<=m;++j){
rr char c=getchar();
while (!isalnum(c)) c=getchar();
if (isdigit(c)) cost[i][j]=c^48;
else if (islower(c)) cost[i][j]=c-87;
else cost[i][j]=c-29;
}
for (rr int i=1;i<=n;++i)
for (rr int j=1;j<=m;++j){
rr char c=getchar();
while (!isalnum(c)) c=getchar();
if (isdigit(c)) reward[i][j]=c^48;
else if (islower(c)) reward[i][j]=c-87;
else reward[i][j]=c-29;
ans+=reward[i][j];
}
for (rr int i=1;i<=n;++i)
for (rr int j=1;j<=m;++j)
if ((i^j)&1){
add(s,ide(i,j)+n*m,cost[i][j]);
add(ide(i,j)+n*m,ide(i,j),reward[i][j]);
for (rr int k=0;k<4;++k){
rr int x=i+dx[k],y=j+dy[k];
if (x<1||x>n||y<1||y>m) continue;
add(ide(i,j),ide(x,y)+n*m,inf);
add(ide(i,j)+n*m,ide(x,y),inf);
}
}else add(ide(i,j),ide(i,j)+n*m,reward[i][j]),
add(ide(i,j)+n*m,t,cost[i][j]);
while (bfs(s)) ans-=dfs(s,inf);
return !printf("%d",ans);
}
JZOJ 4018 Magic
题目
有一个圆,圆上有\(2*n\)个点按顺序编号,圆内有\(n\)条弦,这些弦不相交于圆上,
选取三根弦,这六个点顺次连接变成一个正六边形的形状,把三条弦重新连接,
如果这个新的六边形关于正六边形外接圆的圆心中心对称,那么即为一种方案,问共有多少种方案
分析

分类讨论,
首先答案就是前两种的总和,显然不好处理
那就用总方案\(C(n,3)\)减去后三种,用树状数组求出当前边的左边的边个数\(x\),
就可以求出与该边相交的边个数\(z\),用\(n-1\)减去这两种边就是当前边右边的边\(y\)
首先第三种情况就是\(x*y\),第四五种情况都是\((x+y)*z\),因为会算重,所以要除以2
代码
#include <cstdio>
#include <cctype>
#define rr register
using namespace std;
int n,f[200011],c[200011]; long long ans,ans1;
inline signed iut(){
rr int ans=0; rr char c=getchar();
while (!isdigit(c)) c=getchar();
while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();
return ans;
}
inline void update(int x){for (;x<=n;x+=-x&x) ++c[x];}
inline signed query(int x){rr int ans=0; for (;x;x-=-x&x) ans+=c[x]; return ans;}
signed main(){
n=iut();
for (rr int i=1,x;i<=n;++i)
x=iut(),f[f[x]=iut()]=x;
ans=1ll*n*(n-1)*(n-2)/6,n<<=1;
for (rr int i=1,cnt=0;i<=n;++i)
if (i>f[i]){
rr int x=cnt-query(f[i]-1),z=i-f[i]-1-x*2,y=n/2-1-x-z;
update(f[i]),++cnt,ans-=1ll*x*y,ans1+=1ll*(x+y)*z;
}
return !printf("%lld",ans-ans1/2);
}
#网络流,树状数组#JZOJ 4020 Revolution with JZOJ 4018 Magic的更多相关文章
- D 洛谷 P3602 Koishi Loves Segments [贪心 树状数组+堆]
题目描述 Koishi喜欢线段. 她的条线段都能表示成数轴上的某个闭区间.Koishi喜欢在把所有线段都放在数轴上,然后数出某些点被多少线段覆盖了. Flandre看她和线段玩得很起开心,就抛给她一个 ...
- BZOJ 1103: [POI2007]大都市meg [DFS序 树状数组]
1103: [POI2007]大都市meg Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2221 Solved: 1179[Submit][Sta ...
- bzoj1878--离线+树状数组
这题在线做很麻烦,所以我们选择离线. 首先预处理出数组next[i]表示i这个位置的颜色下一次出现的位置. 然后对与每种颜色第一次出现的位置x,将a[x]++. 将每个询问按左端点排序,再从左往右扫, ...
- codeforces 597C C. Subsequences(dp+树状数组)
题目链接: C. Subsequences time limit per test 1 second memory limit per test 256 megabytes input standar ...
- BZOJ 2434: [Noi2011]阿狸的打字机 [AC自动机 Fail树 树状数组 DFS序]
2434: [Noi2011]阿狸的打字机 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 2545 Solved: 1419[Submit][Sta ...
- BZOJ 3529: [Sdoi2014]数表 [莫比乌斯反演 树状数组]
3529: [Sdoi2014]数表 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1399 Solved: 694[Submit][Status] ...
- BZOJ 3289: Mato的文件管理[莫队算法 树状数组]
3289: Mato的文件管理 Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 2399 Solved: 988[Submit][Status][Di ...
- 【Codeforces163E】e-Government AC自动机fail树 + DFS序 + 树状数组
E. e-Government time limit per test:1 second memory limit per test:256 megabytes input:standard inpu ...
- 【BZOJ-3881】Divljak AC自动机fail树 + 树链剖分+ 树状数组 + DFS序
3881: [Coci2015]Divljak Time Limit: 20 Sec Memory Limit: 768 MBSubmit: 508 Solved: 158[Submit][Sta ...
- 树形DP+DFS序+树状数组 HDOJ 5293 Tree chain problem(树链问题)
题目链接 题意: 有n个点的一棵树.其中树上有m条已知的链,每条链有一个权值.从中选出任意个不相交的链使得链的权值和最大. 思路: 树形DP.设dp[i]表示i的子树下的最优权值和,sum[i]表示不 ...
随机推荐
- 推导式,集合推导式,生成器表达式及生成器函数day13
1.推导式 用一行循环判断遍历处一系列数据的方式 推导式在使用时,只能用for循环和判断,而且判断只能是单项判断 基本语法: lst = [i for i in range(1,51)] print( ...
- Python函数每日一讲 - 一文让你彻底掌握Python中的frozenset函数
引言 在 Python 中,frozenset() 函数是一个重要的工具,用于创建不可变的集合对象.本文将介绍 frozenset() 函数的语法.用法示例以及实际应用场景,帮助大家更好地理解和应用这 ...
- CSP 2023 My Codes
T1 小苹果 题目描述 小 Y 的桌子上放着 \(n\) 个苹果从左到右排成一列,编号为从 \(1\) 到 \(n\). 小苞是小 Y 的好朋友,每天她都会从中拿走一些苹果. 每天在拿的时候,小苞都是 ...
- 16. Class字节码结构
1. 相关概念 1.1字节码文件的跨平台性 Java 语言是跨平台的(write once, run anywhere) 当 Java 源代码成功编译成字节码后,如果想在不同的平台上面运行, 则无须再 ...
- 2022年RPA行业发展十大趋势,六千字长文助你看懂RPA
2022年RPA行业发展十大趋势,六千字长文助你看懂RPA 2022年RPA行业如何发展?十大趋势助你看懂RPA行业未来 这里有2022年RPA行业发展的十大趋势,关注RPA的朋友定要收藏! 文/王吉 ...
- 统一身份认证系统 OpenLDAP 完整部署
0)LDAP 介绍 LDAP 是什么?在那些地方用会用到 LDAP? LDAP英文名称:Lightweight Directory Access Protocol 轻型目录访问协议. 常用在单点登录, ...
- Fiddler 延迟请求
1.开启浏览器代理 2.fiddler设置要抓取的域名 3.设置fiddler代理端口 Tools->Options->Connections 4.设置接口延时 5.访问页面即可延时此接口
- crypto-js DES加密 base64 post传输
演示地址: http://pengchenggang.gitee.io/crypto-js-des/ 开源地址: https://gitee.com/pengchenggang/crypto-js-d ...
- 【机器学习】统计学习方法读书笔记-EM算法(期望最大化算法)
Expectation Maximization,EM算法是带有隐变量的概率模型参数的极大似然估计(MLE为给定参数,观测数据出现/生成的可能性). 如下为<统计机器学习>中对应EM算法的 ...
- TLV320ADC3101这颗立体声 ADC芯片分析体验及总结
一 需求分析 音频ADC采集,顾名思义,就是采集语音信号的ADC.随着基于音视频穿戴式设备的广泛应用,音频ADC使用十分广泛.TI的这颗ADC芯片凭借着先发优势,在很多领域已经有广泛的应用了. 作为一 ...