今年SDOI的题,看到他们在做,看到过了一百多个人,然后就被虐惨啦。。。

果然考试的时候还是打不了高端算法,调了。。。几天

默默地yy了一个费用流构图:

源连所有点,配对的点连啊,所有点连汇。。。

后来罗爷爷提醒我这样子会wa,因为你无法保证所有点都没有超过B[I]次,too naive

正解是还要考虑到奇数/偶数个质数的数字,把它们变成可二分图,看出这个性质就OK了。。。

至于要保证费用下界的问题,这个。。我也不知道为什么我原来的方法不行

后来照着标程改的,加了一行memset就过了,一脸懵逼

又贡献了一道orzliyicheng没过的题,yeah~O(∩_∩)O

#include<cstdio>
#include<algorithm>
#include<cstring>
#define mo 200000
#define value pri
#define N 200000
#define vis flag
#define ll long long
#define inf 10000000000000LL
using namespace std;
ll maxn=,S,T,num,n,edgenum;
ll ans,tmp;
ll next[N],head[N],up[N],flag[N],vet[N],pri[N],from[N],cost[N],q[N],dis[N],a[N],b[N],c[N],f[N];
void add(int u,int v,ll w,ll c)
{
  //printf("%d %d %lld %lld\n",u,v,w,c);
  edgenum++;vet[edgenum]=v;next[edgenum]=head[u];head[u]=edgenum;
  pri[edgenum]=w;cost[edgenum]=c;from[edgenum]=u;
}
ll min(ll a,ll b)
{
  if(a<b)return a;else return b;
}
bool spfa()
{
    memset(dis,,sizeof(dis));
    memset(up,,sizeof(up));
    dis[S]=;
    vis[S]=;
    q[]=S;
    ;,tail=;
    while (tou<=tail)
    {
        ;//printf("query=%d\n",x);
        for (int i=head[x];i;i=next[i])
        if (pri[i]&&dis[vet[i]]>dis[x]+cost[i])
        {
           //printf("vet=%d\n",vet[i]);
            dis[vet[i]]=dis[x]+cost[i];
            up[vet[i]]=i;
            ,tail++,q[tail%mo]=vet[i];//printf("tail=%d\n",tail);
            ;
        }
        tou++;
    }
    //for(int i=0;i<=T;i++)printf("%lld ",dis[i]);printf("\n");
    ;
    ;
}
bool flow()
{
    int minn=inf;
    for (int i=up[T];i;i=up[from[i]])
        minn=min(minn,pri[i]);
    //printf("min==%lld %lld\n",dis[T],minn);
    )
    {
        for (int i=up[T];i;i=up[from[i]])
        {
            ;==)ee=i-;
            pri[i]-=minn;
            pri[ee]+=minn;
        }
        ans+=minn;
        tmp+=dis[T]*minn;
        ;
    }
    ;}
}
void dinic()
{
  ans=;tmp=;
  ;i<=T;i++)flag[i]=;
 while (spfa()&&flow());
    printf("%lld",ans);
}
ll calc(ll x)
{
  ll ans=;
  ;i<=num;i++)
   )
   {
     x/=pri[i];ans++;
   }
  )ans++;return ans;
}
int main()
{
freopen("4514.in","r",stdin);
freopen("4514.out","w",stdout);
  scanf("%lld",&n);
  ;i<=n;i++)scanf("%lld",&a[i]);
  ;i<=n;i++)scanf("%lld",&b[i]);
  ;i<=n;i++)scanf("%lld",&c[i]);
  ;i<=maxn;i++)
  {
    )num++,pri[num]=i;
    ;j<=num;j++)
    {
      if(pri[j]*i>maxn)break;
      flag[pri[j]*i]=;
      )break;
    }
  }
  ;i<=n;i++)f[i]=calc(a[i]);
  S=n+,T=n+;
  ;i<=n;i++)
   ==)add(S,i,b[i],),add(i,S,,);),add(T,i,,);
  ;i<=n;i++)
   ;j<=n;j++)
    ))
    {
      int u,v;
      ==)u=i;==)v=i;else v=j;
      add(u,v,inf,-c[i]*c[j]);//printf("%d %d\n",c[i],c[j]);
      add(v,u,,c[i]*c[j]);
    }
  dinic();
}

[bzoj4514]数字配对[费用流]的更多相关文章

  1. [SDOI2016][bzoj4514] 数字配对 [费用流]

    题面 传送门 思路 一个数字能且只能匹配一次 这引导我们思考:一次代表什么?代表用到一定上限(b数组)就不能再用,同时每用一次会产生价值(c数组) 上限?价值?网络流! 把一次匹配设为一点流量,那产生 ...

  2. 【BZOJ4514】[Sdoi2016]数字配对 费用流

    [BZOJ4514][Sdoi2016]数字配对 Description 有 n 种数字,第 i 种数字是 ai.有 bi 个,权值是 ci. 若两个数字 ai.aj 满足,ai 是 aj 的倍数,且 ...

  3. 【BZOJ4514】【SDOI2016】数字配对 [费用流]

    数字配对 Time Limit: 10 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 有 n 种数字,第 i 种数字是 ...

  4. bzoj4514: [Sdoi2016]数字配对--费用流

    看了一眼题目&数据范围,觉得应该是带下界的费用流 原来想拆点变成二分图,能配对的连边,跑二分图,可行性未知 后来看到另外一种解法.. 符合匹配要求的数要满足:质因子的个数相差为1,且两者可整除 ...

  5. BZOJ 4514: [Sdoi2016]数字配对 [费用流 数论]

    4514: [Sdoi2016]数字配对 题意: 有 n 种数字,第 i 种数字是 ai.有 bi 个,权值是 ci. 若两个数字 ai.aj 满足,ai 是 aj 的倍数,且 ai/aj 是一个质数 ...

  6. BZOJ.4514.[SDOI2016]数字配对(费用流SPFA 二分图)

    BZOJ 洛谷 \(Solution\) 很显然的建二分图后跑最大费用流,但有个问题是一个数是只能用一次的,这样二分图两部分都有这个数. 那么就用两倍的.如果\(i\)可以向\(j'\)连边,\(j\ ...

  7. 【BZOJ 4514】[Sdoi2016]数字配对 费用流

    利用spfa流的性质,我直接拆两半,正解分奇偶(妙),而且判断是否整除且质数我用的是暴力根号,整洁判断质数个数差一(其他非spfa流怎么做?) #include <cstdio> #inc ...

  8. 4514: [Sdoi2016]数字配对 费用流

    链接 https://www.lydsy.com/JudgeOnline/problem.php?id=4514 思路 EK直接贪心做 <0的时候加上剩余返回 二分图a->b的时候 把b- ...

  9. bzoj4514 数字配对

    思路 首先想到费用流. 对于每个点拆点.然后考虑我们怎样才能保证每个点只被用一次. 如果\(i\)与\(j\)满足条件.那么就从\(i\)向\(j\)连一条边并且从\(j\)向\(i\)连一条边.这样 ...

随机推荐

  1. IOS - 控件的AutoresizingMask属性

    在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. enum {   UIViewAutoresi ...

  2. php处理图片实现

    <?php include("SimpleImage.php");//图片处理类在下面 $url="http://f3.v.veimg.cn/meadincms/1 ...

  3. <context-param>与<init-param>

    <context-param>的作用: web.xml的配置中<context-param>配置作用1. 启动一个WEB项目的时候,容器(如:Tomcat)会去读它的配置文件w ...

  4. 查看base64编码图片

    1.确认编码纯净(没有编码参数) 2.在头部加上 data:image/jpeg;base64, 3.放到浏览器查看

  5. 【SSO单点系列】(1):CAS4.0 环境的搭建

    一.概述 今天开始写CAS相关的第一篇文章,这篇文章主要是关于CAS环境的搭配,提供给刚刚接触CAS的一个入门指南,并演示一个CAS的最简单的实例 二.环境要求 博主的环境如下: win8.1 64 ...

  6. Swift - 懒加载(lazy initialization)

    Swift中是存在和OC一样的懒加载机制的,在程序设计中,我们经常会使用 懒加载 ,顾名思义,就是用到的时候再开辟空间 懒加载 格式: lazy var 变量: 类型 = { 创建变量代码 }() 懒 ...

  7. DB2 上copy表结构及数据

    现已有一行数据,要复制为多行,每行只有两个字段值不同,db2 没有sql server的top关键字,本只想复制几次,然后update逐条数据,发现不行. 然后想到不如临时创建一张表B,插入此行数据, ...

  8. HTML5学习之智能表单(二)

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  9. js 上传文件后缀名的判断 var flag=false;应用

    js 上传文件后缀名的判断  var flag=false;应用 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional// ...

  10. PHP保留小数位的三种方法

    /** * PHP保留两位小数的几种方法 * @link http://www.phpddt.com */ $num = 10.4567; //第一种:利用round()对浮点数进行四舍五入 echo ...