wordpress论坛模板下载地址/360seo排名点击软件

wordpress论坛模板下载地址,360seo排名点击软件,电子商务的概念,导出WordPress文件格式很妙的一道题 对于每个格子,它合法与否,只跟它上下左右的相邻格子有关,所以可以想到黑白染色 (用 (i,j) 表示 i 行 j 列的格子,我把 (ij) %2 0 的格子染成白色,把(ij)%2 1 的格子染成黑色) …

很妙的一道题

对于每个格子,它合法与否,只跟它上下左右的相邻格子有关,所以可以想到黑白染色
(用 (i,j) 表示 i 行 j 列的格子,我把 (i+j) %2 == 0 的格子染成白色,把(i+j)%2 == 1 的格子染成黑色)

关键是怎么描述旋转操作

我朴实的想法是给每个格子建四个点,每个点代表格子可通过旋转达到的一种状态,从格子的初始状态向格子其它状态连边,然后把格子间可以匹配的状态连起来,再然后……就没有然后了

看了题解,真的被惊到了
还是把每个格子拆成4个节点,对应四个方向上的接口
从源点向白格的接口连流量上界1,费用0的边
从黑格的接口向汇点连流量上界1,费用0的边
从黑格的接口向可以匹配的白格的接口连流量上界1,费用0的边
然后旋转操作,就可以通过一种神奇方式描述出来:

	AD	O	BC

把这个看成一个白格(黑格类似,只是连边方向相反)
边(u->v,f,w)代表从 u 到 v,流量上界 f,费用 w 的边
下文描述的旋转方向均为顺时针
1.此格有1个接口:

	A|
D	O	BC

(A->B ,1,1)) 对应转90度
(A->C, 1,2)) 对应转180度
(A->D ,1,1)) 对应转270度
2.此格有2个接口:
情况1:

	 A|
D	 O —— BC

(A->C, 1,1)) 对应转90度
(B->D ,1,1)) 对应转270度
(A->C, 1,1))+(B->D ,1,1)) 对应转180度
情况2:

	A|
D	O	B|C

不能转,忽略
3.此格有3个接口:

	 A|
D 	 O —— B|C

(A->D ,1,1)) 对应转270度
(B->D, 1,2)) 对应转180度
(C->D ,1,1)) 对应转90度
4.此格有4个接口:

	 A|
D —— O —— B|C

转了也没区别,忽略

建完图后跑最小费用最大流即可

如果我表达不清的话,这是样例1的建图,很丑,凑合着看吧
在这里插入图片描述
图上标的数代表费用,没标的边默认费用为0,所有边的流量上界默认为1

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
const int inf=0x7fffffff;
const int N=8100;
const int M=200010;
struct Edge{int u,v,f,w,nxt;
}edge[M<<1];
int s,t,head[N],cnt,maxflow,mincost,dis[N],inque[N],pre[N];
queue<int> q;
int n,m,id[2005][2005][4],num,gr[2005][2005],tot;
void add(int u,int v,int f,int w){edge[cnt].u=u;edge[cnt].v=v;edge[cnt].f=f;edge[cnt].w=w;edge[cnt].nxt=head[u];head[u]=cnt++;edge[cnt].u=v;edge[cnt].v=u;edge[cnt].f=0;edge[cnt].w=-w;edge[cnt].nxt=head[v];head[v]=cnt++;
}
bool spfa(){memset(dis,0x7f,sizeof(dis));memset(inque,0,sizeof(inque));memset(pre,-1,sizeof(pre));dis[s]=0;q.push(s);inque[s]=1;while(!q.empty()){int u=q.front();q.pop();inque[u]=0;for(int i=head[u];i!=-1;i=edge[i].nxt){int v=edge[i].v;if(edge[i].f>0&&dis[v]>dis[u]+edge[i].w){dis[v]=dis[u]+edge[i].w;pre[v]=i;if(!inque[v]){q.push(v);inque[v]=1;}}}} if(pre[t]!=-1) return 1;return 0;
}
void EK(){int flow;while(spfa()){flow=inf;int x=pre[t];while(x!=-1){flow=min(edge[x].f,flow);x=pre[edge[x].u];}x=pre[t];while(x!=-1){edge[x].f-=flow;edge[x^1].f+=flow;mincost+=flow*edge[x].w;x=pre[edge[x].u];}maxflow+=flow;}
}
int main(){memset(head,-1,sizeof(head));scanf("%d%d",&n,&m);for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)for(int k=0;k<4;k++)id[i][j][k]=++num;s=++num,t=++num;		for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){scanf("%d",&gr[i][j]);int tt=0,pos[5]={-1,-1,-1,-1,-1},npos=-1;for(int k=0;k<4;k++){if(gr[i][j]&(1<<k)){tot++;pos[++tt]=k;if((i+j)%2==0) add(s,id[i][j][k],1,0);else add(id[i][j][k],t,1,0);}else npos=k;}if(tt==1){if((i+j)%2==0){add(id[i][j][pos[1]],id[i][j][(pos[1]+1)%4],1,1);add(id[i][j][pos[1]],id[i][j][(pos[1]+2)%4],1,2);add(id[i][j][pos[1]],id[i][j][(pos[1]+3)%4],1,1);}else{add(id[i][j][(pos[1]+1)%4],id[i][j][pos[1]],1,1);add(id[i][j][(pos[1]+2)%4],id[i][j][pos[1]],1,2);add(id[i][j][(pos[1]+3)%4],id[i][j][pos[1]],1,1);}}else if(tt==2){if(pos[2]-pos[1]==2) continue;if((i+j)%2==0){add(id[i][j][pos[1]],id[i][j][(pos[1]+2)%4],1,1);add(id[i][j][pos[2]],id[i][j][(pos[2]+2)%4],1,1);}else{add(id[i][j][(pos[1]+2)%4],id[i][j][pos[1]],1,1);add(id[i][j][(pos[2]+2)%4],id[i][j][pos[2]],1,1);}}else if(tt==3){if((i+j)%2==0){add(id[i][j][(npos+1)%4],id[i][j][npos],1,1);add(id[i][j][(npos+2)%4],id[i][j][npos],1,2);add(id[i][j][(npos+3)%4],id[i][j][npos],1,1);}else{add(id[i][j][npos],id[i][j][(npos+1)%4],1,1);add(id[i][j][npos],id[i][j][(npos+2)%4],1,2);add(id[i][j][npos],id[i][j][(npos+3)%4],1,1);}}else continue;}}//一开始这一块的建图错了 int dx[]={-1,0,1,0};int dy[]={0,1,0,-1};for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){if((i+j)%2==0){for(int k=0;k<=3;k++){int x=i+dx[k],y=j+dy[k];if(x<1||x>n||y<1||y>m) continue;add(id[i][j][k],id[x][y][(k+2)%4],1,0);}}}}EK();if(tot%2!=0||maxflow!=tot/2) printf("-1\n"); //注意还要判断tot%2!=0的情况 else printf("%d\n",mincost);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320268.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ASP.NET Core 中的 ORM 之 Dapper

Dapper简介Dapper是.NET的一款轻量级ORM工具&#xff08;GitHub&#xff09;&#xff0c;也可称为简单对象映射器。在速度方面拥有微型ORM之王的称号。它是半自动的&#xff0c;也就是说实体类和SQL语句都要自己写&#xff0c;但它提供自动对象映射。是通过对IDbConnection接口…

用WinForm/WPF代码来为.NET Core 3.0功能投票

我们在5月报道过微软希望在.NET Core 3.0上运行WinForms和WPF。为了实现这个目标&#xff0c;他们正在构建一个新工具&#xff0c;该工具将允许你投票以决定他们需要把哪些API移植到.NET Core。但是&#xff0c;这不是一次直接进行的投票&#xff0c;而是基于你的应用程序正在使…

病毒扩散

链接&#xff1a; 时间限制&#xff1a;C/C 2秒&#xff0c;其他语言4秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20200429210705568.png?x-oss-processimage/waterm…

【SPFA】Party(jzoj 1328)

Party jzoj 1328 题目大意 有一个有向图&#xff0c;给你一个x&#xff0c;让你求每一个点到x再回去的最短路径&#xff0c;输出所有最短路径的最大值 输入样例 4 8 2 1 2 4 1 3 2 1 4 7 2 1 1 2 3 5 3 1 2 3 4 4 4 2 3输出样例 10 样例解释 数据范围 1⩽x⩽N⩽10001\le…

Asp.Net Core 2.2.0-preview1已经发布

原文地址 ASP.NET Core 2.2.0-preview1 now available今天我们很高兴地宣布,现在可以试用ASP.NET Core和.NET Core的下一个次要版本的第一个预览。在过去的几个月里&#xff0c;我们和社区里的许多人一起为这个版本进行开发&#xff0c;现在它已经准备好让更广泛的受众尝试它并…

UOJ284 快乐游戏鸡(树上动态规划问题、长链剖分+单调栈)

Description 一棵 n 个点的有根树&#xff0c;带点权 wi。 从 s 出发&#xff0c;希望达到 t&#xff0c;每秒可以从当前点移动到某一个儿子。 有一个死亡次数&#xff0c;初始为 0。若在某个点 i(i ! s, t) 时&#xff0c;死亡次数 ≤ wi&#xff0c;那么死亡次数自增 1&…

C#系列之聊聊.Net Core的InMemoryCache

这两天在看.net core的in memory cache&#xff0c;这里记录一下用法&#xff0c;主要涉及MemoryCache的Get&#xff0f;Set&#xff0f;Expire&#xff0f;Flush。首先我们先用dotnet命令创建一个mvc的项目&#xff0c;这里我们将使用postman来请求server&#xff0c;1dotnet …

小石的签到题

链接&#xff1a; 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 输入描述: 共一行&#xff0c;输入一个数 n 。 输出描述: 共一行&#xff0c;输出 “Shi” 或 “Yang”&…

CAP带你轻松玩转ASP.NETCore消息队列

CAP是什么&#xff1f;CAP是由我们园子里的杨晓东大神开发出来的一套分布式事务的决绝方案&#xff0c;是.Net Core Community中的第一个千星项目&#xff08;目前已经1656 Start&#xff09;&#xff0c;具有轻量级、易使用、高性能等特点。https://github.com/dotnetcore/CAP…

装备合成

链接&#xff1a; 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 输入描述: 输入包含t组数据 第一行一个整数t 接下来t行每行两个整数x,y 输出描述: 每组数据输出一行一个…

微软必应从.NET Core 2.1获得了性能提升

据微软工程师Mukul Sabharwal介绍&#xff0c;在将微软搜索引擎必应迁移到.NET Core 2.1之后&#xff0c;内部服务延迟降低了34%&#xff0c;这主要归功于.NET社区贡献的改进。按照Sabharwal的说法&#xff0c;.NET Core的多项改进贡献了大部分的性能提升&#xff0c;包括字符串…

搭建基于云端的中间层以支持跨平台的智能视觉服务

不断演进的应用场景初级应用场景—宅在家里场景&#xff1a;Bob同学有一天在网上看到了一张建筑物的图片&#xff0c;大发感慨&#xff1a;"好漂亮啊&#xff01;这是哪里&#xff1f;我要去亲眼看看&#xff01;"Bob同学不想问别人&#xff0c;可笑的自尊心让他觉得…

高等数学超入门学习笔记

极限 百度百科 1.数列极限 百度百科 1.1 数列 1.2 数列极限 1.3 单调收敛原理 {xn}\{x_n\}{xn​}单调递增且{xn}\{x_n\}{xn​}有上界&#xff08;可以找到实数M使{xn}\{x_n\}{xn​}中任意一项小于M&#xff09;&#xff0c;{xn}\{x_n\}{xn​}收敛&#xff08;存在象限a&…

Microsoft宣布正式发布Linux on ASE

Microsoft宣布正式发布&#xff08;GA&#xff09;用于ASE&#xff08;应用服务环境&#xff0c;App Service Environment&#xff09;的Linux。该服务使客户可结合使用Linux上的应用服务&#xff08;App Service&#xff09;特性与ASE。在正式发布版之前&#xff0c;Microsoft…

Rinne Loves Xor

链接&#xff1a; 来源&#xff1a;牛客网 时间限制&#xff1a;C/C 2秒&#xff0c;其他语言4秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 输入描述: 第一行一个整数 N&#xff0c;表示数组 A 和 B 的长度。 第二行 N …

Pipelines - .NET中的新IO API指引(一)

原文&#xff1a;https://blog.marcgravell.com/2018/07/pipe-dreams-part-1.html作者&#xff1a;marcgravell大约两年前&#xff0c;我发表了一篇关于.NET中即将到来的体验性新IO API的博文——在那时它被叫做"Channels"&#xff1b;在2018年的五月末&#xff0c;它…

[XSY] 分割(dfs树)

分割 题目相当于问 删掉两个点后 图是否仍然连通 割点问题&#xff0c;考虑用dfs树解决 设删去点u&#xff0c;v&#xff08;dfn[v]<dfn[u]&#xff09; 把 u, v 删去之后整棵树大概断成了几个部分&#xff1a; • v 上面到根的部分&#xff0c;以及上面挂着的那些东西&…

三分法讲解

二分用到的挺多&#xff0c;三分用的少&#xff0c;但也不能忘。。。 二分我们常常用于一个具有单调性的情况中求解某值 而三分就像是求一个凸性或凹形函数时&#xff0c;来求那个凹凸点 一开始L0&#xff0c;Rinf&#xff0c;然后也是不断缩小L与R的范围&#xff0c;逼近最值…

使用C#读写结构化的二进制文件

最近工作上遇到一个问题&#xff0c;就是有将近200万个CSV文件&#xff0c;每个CSV文件包含了成千上万条实验数据&#xff0c;CSV以一个不连续的整数值作为文件名&#xff0c;比如&#xff1a;1.CSV、2.CSV、3.CSV、5.CSV等等。另外又有200万个XML文件&#xff0c;每个XML文件的…

牛客IOI周赛16-普及组

比赛链接 文章目录求导题目描述题解&#xff1a;猜数题意&#xff1a;题解&#xff1a;方法一 贪心方法二 暴力答题卡题意&#xff1a;题解&#xff1a;代码&#xff1a;求导 链接&#xff1a; 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C …