【传送门:BZOJ3158


简要题意:

  给出n个机器,每个机器有a[i]基础值和b[i]价值

  选出一部分机器使得这些机器里面两两至少满足以下两种条件之一:

  1.a[i]2+a[j]2!=T2(T为正整数)

  2.gcd(a[i],a[j])>1

  求出能达到要求的最大价值


题解:

  神最小割

  要求一个最大价值,那么我们可以转换成求损失的价值最小

  但是这里两个子集的分化并不明显

  对于第二个要求,如果两点的a值都为偶数,那么肯定满足

  那如果两个数都为奇数的话,也必定满足要求一,证明如下:

  1、一个奇数的平方%4为1,一个偶数的平方%4为0

  2、两个奇数的平方和%4为2

  3、如果两个奇数的平方和是一个奇数的平方,那么%4应该为1,不符合

  4、如果两个奇数的平方和是一个偶数的平方,那么%4应该为0,不符合

  这样子思考的话,两个子集的分化就较为明显了:

  st向a值为奇数的相连,a值为偶数的向ed相连,容量都为b值;

  这样子所形成的两个子集里面的点一定都是符合要求的。

  最后一步,也是最关键的一步:

  两个子集之间两两匹配,如果当前匹配的两个点是不符合要求的,就将这两个点相连,容量为无限大。

  跑最小割,割出来的边就是损失价值的最小值 用sum-最小割就是答案

  by Cherish_OI

  注意要加long long


参考代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cstdlib>
#include<cmath>
using namespace std;
typedef long long LL;
struct node
{
int x,y,next,other;LL c;
}a[];int len,last[];
void ins(int x,int y,LL c)
{
int k1=++len,k2=++len;
a[k1].x=x;a[k1].y=y;a[k1].c=c;
a[k1].next=last[x];last[x]=k1;
a[k2].x=y;a[k2].y=x;a[k2].c=;
a[k2].next=last[y];last[y]=k2;
a[k1].other=k2;
a[k2].other=k1;
}
int h[],list[],st,ed;
bool bt_h()
{
memset(h,,sizeof(h));h[st]=;
list[]=st;
int head=,tail=;
while(head!=tail)
{
int x=list[head];
for(int k=last[x];k;k=a[k].next)
{
int y=a[k].y;
if(a[k].c>&&h[y]==)
{
h[y]=h[x]+;
list[tail++]=y;
}
}
head++;
}
if(h[ed]==) return false;
else return true;
}
LL findflow(int x,LL f)
{
if(x==ed) return f;
int s=,t;
for(int k=last[x];k;k=a[k].next)
{
int y=a[k].y;
if(a[k].c>&&h[y]==(h[x]+)&&f>s)
{
t=findflow(y,min(a[k].c,f-s));
s+=t;
a[k].c-=t;a[a[k].other].c+=t;
}
}
if(s==) h[x]=;
return s;
}
LL gcd(LL a,LL b)
{
if(a==) return b;
else return gcd(b%a,a);
}
LL A[],B[];
bool check(LL x,LL y)
{
LL c=sqrt(x*x+y*y);
if(c*c!=x*x+y*y) return false;
if(gcd(x,y)>) return false;
return true;
}
int main()
{
int n;
scanf("%d",&n);
st=;ed=n+;
len=;memset(last,,sizeof(last));
LL sum=;
for(int i=;i<=n;i++)
{
scanf("%lld",&A[i]);
sum+=A[i];
if(A[i]%==) ins(st,i,A[i]);
else ins(i,ed,A[i]);
}
for(int i=;i<=n;i++)
{
for(int j=;j<=n;j++)
{
if(check(A[i],A[j])==true&&(A[i]%==)&&(A[j]%==))
{
ins(i,j,);
}
}
}
while(bt_h()==true) sum-=findflow(st,);
printf("%lld\n",sum);
return ;
}

BZOJ3158: 千钧一发的更多相关文章

  1. BZOJ3158 千钧一发(最小割)

    可以看做一些物品中某些互相排斥求最大价值.如果这是个二分图的话,就很容易用最小割了. 观察其给出的条件间是否有什么联系.如果两个数都是偶数,显然满足条件二:而若都是奇数,则满足条件一,因为式子列出来发 ...

  2. [bzoj3158]千钧一发——二分图+网络流

    题目 传送门 题解 很容易建立模型,如果两个点不能匹配,那么连一条边,那么问题就转化为了求一个图上的最大点权独立集. 而我们可以知道: 最大点权独立集+最小点权覆盖集=总权值. 同时最小点权覆盖在一般 ...

  3. 【BZOJ3158】千钧一发 最小割

    [BZOJ3158]千钧一发 Description Input 第一行一个正整数N. 第二行共包括N个正整数,第 个正整数表示Ai. 第三行共包括N个正整数,第 个正整数表示Bi. Output 共 ...

  4. 【bzoj3158】 千钧一发

    http://www.lydsy.com/JudgeOnline/problem.php?id=3158 (题目链接) 题意 给出n个装置,每个装置i有一个特征值a[i]和一个能量值b[i],要求选出 ...

  5. bzoj3158&3275: 千钧一发(最小割)

    3158: 千钧一发 题目:传送门 题解: 这是一道很好的题啊...极力推荐 细看题目:要求一个最大价值,那么我们可以转换成求损失的价值最小 那很明显就是最小割的经典题目啊?! 但是这里两个子集的分化 ...

  6. 【BZOJ-3275&3158】Number&千钧一发 最小割

    3275: Number Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 748  Solved: 316[Submit][Status][Discus ...

  7. BZOJ 3158: 千钧一发

    3158: 千钧一发 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1201  Solved: 446[Submit][Status][Discuss ...

  8. 【BZOJ】【3158】千钧一发

    网络流/最小割 这题跟BZOJ 3275限制条件是一样的= =所以可以用相同的方法去做……只要把边的容量从a[i]改成b[i]就行了- (果然不加当前弧优化要略快一点) /************** ...

  9. bzoj 3158 千钧一发(最小割)

    3158: 千钧一发 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 767  Solved: 290[Submit][Status][Discuss] ...

随机推荐

  1. NOIp2018模拟赛四十一

    现在是下午15:36,我已经改完题了...刷新纪录 A题叫B,B题叫A是什么操作??? 我离200只差一个SBFA.jpg 成绩:0+100+10=110 被虐啦...今天九个阿克的Orz.A题是个神 ...

  2. [洛谷P1750]KC喝咖啡

    题目大意:给你n个物品,每个物品有一个价值$v_i$和一个时间$t_i$,要你取m个物品,使得他们的美味度($\frac{\sum v_i}{\sum t_i}$)最大,求这个美味度. 解题思路:由于 ...

  3. 你可能需要了解下Laravel集合

    前言 集合通过 Illuminate\Support\Collection 进行实例,Laravel的内核大部分的参数传递都用到了集合,但这并不代表集合就是好的.Laravel作为快捷并优雅的开发框架 ...

  4. caioj 1158 欧拉函数

    直接套模板,这道题貌似单独求还快一些 解法一 #include<cstdio> #include<cctype> #define REP(i, a, b) for(int i ...

  5. USACO 玛丽卡(最短路+枚举)

    USACO 玛丽卡 麦克找了个新女朋友,玛丽卡对他非常恼火并伺机报复. 因为她和他们不住在同一个城市,因此她开始准备她的长途旅行. 在这个国家中每两个城市之间最多只有一条路相通,并且我们知道从一个城市 ...

  6. 实验了一下对于struct引用的成员的改动

    今天写代码的时候,不确定struct用引用传递给函数的时候,他的成员在函数里面改变的时候,是否能影响到外面. 实验了一下 #include <stdio.h> #include <s ...

  7. 【Hibernate学习】 —— 抓取策略(注解方式)

    当应用程序须要在关联关系间进行导航的时候.hibernate怎样获取关联对象的策略. 抓取策略的方式: FetchType.LAZY:懒载入.载入一个实体时.定义懒载入的属性不会立即从数据库中载入. ...

  8. Struts2学习(三)上传下载

    今天记录一下利用struts2实现上传下载,借此案例说明一下struts2的开发流程. 须要注意的是struts2版本号不同非常多地方的写法是不同的.本例使用struts2.3.15 .有差别的地方文 ...

  9. codevs1052

    题目地址:http://codevs.cn/problem/1053/ 分析: 模拟 代码: var s:string; a:array['a'..'z'] of longint; i,j,t,n:l ...

  10. angularjs 工具方法

    <!DOCTYPE HTML> <html ng-app> <head> <meta http-equiv="Content-Type" ...