2127: happiness

Time Limit: 51 Sec  Memory Limit: 259 MB
Submit: 2570  Solved: 1242
[Submit][Status][Discuss]

Description

高一一班的座位表是个n*m的矩阵,经过一个学期的相处,每个同学和前后左右相邻的同学互相成为了好朋友。这学期要分文理科了,每个同学对于选择文科与理科有着自己的喜悦值,而一对好朋友如果能同时选文科或者理科,那么他们又将收获一些喜悦值。作为计算机竞赛教练的scp大老板,想知道如何分配可以使得全班的喜悦值总和最大。

Input

第一行两个正整数n,m。接下来是六个矩阵第一个矩阵为n行m列 此矩阵的第i行第j列的数字表示座位在第i行第j列的同学选择文科获得的喜悦值。第二个矩阵为n行m列 此矩阵的第i行第j列的数字表示座位在第i行第j列的同学选择理科获得的喜悦值。第三个矩阵为n-1行m列 此矩阵的第i行第j列的数字表示座位在第i行第j列的同学与第i+1行第j列的同学同时选择文科获得的额外喜悦值。第四个矩阵为n-1行m列 此矩阵的第i行第j列的数字表示座位在第i行第j列的同学与第i+1行第j列的同学同时选择理科获得的额外喜悦值。第五个矩阵为n行m-1列 此矩阵的第i行第j列的数字表示座位在第i行第j列的同学与第i行第j+1列的同学同时选择文科获得的额外喜悦值。第六个矩阵为n行m-1列 此矩阵的第i行第j列的数字表示座位在第i行第j列的同学与第i行第j+1列的同学同时选择理科获得的额外喜悦值。

Output

输出一个整数,表示喜悦值总和的最大值

Sample Input

1 2
1 1
100 110
1
1000

Sample Output

1210
【样例说明】
两人都选理,则获得100+110+1000的喜悦值。
【数据规模】
对于100%以内的数据,n,m<=100 所有喜悦值均为小于等于5000的非负整数
 
 
 
思路:
 
 
 代码: 
#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 50101
#define M N*30
#define inf 9999999
using namespace std;
queue<int>q;
,ans,cntt;
)*m+j; }
int to[M],cap[N],lev[N],cnt[M],head[M],nextt[M];
int add(int x,int y,int z)
{
    tot++;to[tot]=y;cap[tot]=z;nextt[tot]=head[x];head[x]=tot;
    tot++;to[tot]=x;cap[tot]=;nextt[tot]=head[y];head[y]=tot;
}
inline bool bfs()
{
    while(!q.empty()) q.pop();
    ;i<=cntt;i++)
    {
        lev[i]=-;
        cnt[i]=head[i];
    }
    q.push(s),lev[s]=;
    while(!q.empty())
    {
        int x=q.front();q.pop();
        for(int i=head[x];i;i=nextt[i])
        {
            int t=to[i];
            &&lev[t]==-)
            {
                lev[t]=lev[x]+;
                q.push(t);
                if(t==e) return true;
            }
        }
    }
    return false;
}
int dinic(int x,int flow)
{
    if(x==e) return flow;
    ,delta;
    for(int &i=cnt[x];i;i=nextt[i])
    {
        int t=to[i];
        &&lev[t]>lev[x])
        {
            delta=dinic(t,min(cap[i],flow-rest));
            if(delta)
            {
                cap[i]-=delta;
                cap[i^]+=delta;
                rest+=delta;
                if(rest==flow) break;
            }
        }
    }
    ;
    return rest;
}
int main()
{
    scanf(,e=n*m+;
    ;i<=n;i++)
     ;j<=m;j++)
     {
         scanf("%d",&z);ans+=z;
         add(s,turn(i,j),z);
     }
    ;i<=n;i++)
     ;j<=m;j++)
     {
         scanf("%d",&z);ans+=z;
         add(turn(i,j),e,z);
     }
    cntt=e;
    ;i<n;i++)
     ;j<=m;j++)
      {
          scanf("%d",&z);ans+=z;
          cntt++;
          add(s,cntt,z);
          add(cntt,turn(i,j),inf);
          add(cntt,turn(i+,j),inf);
      }
    ;i<n;i++)
     ;j<=m;j++)
      {
          scanf("%d",&z);ans+=z;
          cntt++;
          add(cntt,e,z);
          add(turn(i,j),cntt,inf);
          add(turn(i+,j),cntt,inf);
          add(cntt-(n-)*m,cntt,inf);
      }
    ;i<=n;i++)
     ;j<m;j++)
     {
        scanf("%d",&z);ans+=z;
        cntt++;
        add(s,cntt,z);
        add(cntt,turn(i,j),inf);
        add(cntt,turn(i,j+),inf);
     }
    ;i<=n;i++)
     ;j<m;j++)
     {
        scanf("%d",&z);ans+=z;
        cntt++;
        add(cntt,e,z);
        add(turn(i,j),cntt,inf);
        add(turn(i,j+),cntt,inf);
        add(cntt-n*(m-),cntt,inf);
     }
     while(bfs())
      ans-=dinic(s,inf);
     printf("%d",ans);
     ;
}

莫名TLE

#include<cstdio>
#include<queue>
#include<algorithm>
#define N 50101
#define M N*30
#define inf 2e9
using namespace std;
;
int lev[N],cap[M],cur[N];
int n,m,src,decc,ans,cnt;
queue<int>q;
)*m+j; }
void add(int u,int v,int w)
{
    to[++tot]=v; nxt[tot]=front[u]; front[u]=tot; cap[tot]=w;
    to[++tot]=u; nxt[tot]=front[v]; front[v]=tot;
}
bool bfs()
{
    while(!q.empty()) q.pop();
    ;i<=cnt;i++) cur[i]=front[i],lev[i]=-;
    lev[src]=; q.push(src);
    int now;
    while(!q.empty())
    {
        now=q.front(); q.pop();
        for(int i=front[now];i;i=nxt[i])
        {
            &&lev[to[i]]==-)
            {
                lev[to[i]]=lev[now]+;
                if(to[i]==decc) return true;
                q.push(to[i]);
            }
        }
    }
    return false;
}
int dinic(int now,int flow)
{
    if(now==decc) return flow;
    ,delta;
    for(int &i=cur[now];i;i=nxt[i])
    {
        &&lev[to[i]]>lev[now])
        {
            delta=dinic(to[i],min(flow-rest,cap[i]));
            if(delta)
            {
                cap[i]-=delta; cap[i^]+=delta;
                rest+=delta; if(rest==flow) break;
            }
        }
    }
    ;
    return rest;
}
int main()
{
    int x;
    scanf("%d%d",&n,&m);
    decc=n*m+;
    ;i<=n;i++)
     ;j<=m;j++)
      {
          scanf("%d",&x); ans+=x;
          add(src,turn(i,j),x);
      }
    ;i<=n;i++)
     ;j<=m;j++)
      {
          scanf("%d",&x); ans+=x;
          add(turn(i,j),decc,x);
      }
    cnt=n*m+;
    ;i<n;i++)
     ;j<=m;j++)
      {
          scanf("%d",&x); ans+=x;
          cnt++;
          add(src,cnt,x);
          add(cnt,turn(i,j),inf);
          add(cnt,turn(i+,j),inf);
      }
    ;i<n;i++)
     ;j<=m;j++)
      {
          scanf("%d",&x); ans+=x;
          cnt++;
          add(cnt,decc,x);
          add(turn(i,j),cnt,inf);
          add(turn(i+,j),cnt,inf);
          add(cnt-(n-)*m,cnt,inf);
      }
    ;i<=n;i++)
     ;j<m;j++)
     {
         scanf("%d",&x); ans+=x;
         cnt++;
         add(src,cnt,x);
         add(cnt,turn(i,j),inf);
         add(cnt,turn(i,j+),inf);
     }
    ;i<=n;i++)
     ;j<m;j++)
     {
         scanf("%d",&x); ans+=x;
         cnt++;
         add(cnt,decc,x);
         add(turn(i,j),cnt,inf);
         add(turn(i,j+),cnt,inf);
         add(cnt-n*(m-),cnt,inf);
     }
    while(bfs()) ans-=dinic(src,inf);
    printf("%d",ans);
}

Ac代码

bzoj——2127: happiness的更多相关文章

  1. BZOJ 2127: happiness [最小割]

    2127: happiness Time Limit: 51 Sec  Memory Limit: 259 MBSubmit: 1815  Solved: 878[Submit][Status][Di ...

  2. [BZOJ 2127] happiness 【最小割】

    题目链接:BZOJ - 2127 题目分析 首先,每个人要么学文科,要么学理科,所以可以想到是一个最小割模型. 我们就确定一个人如果和 S 相连就是学文,如果和 T 相连就是学理. 那么我们再来确定建 ...

  3. [置顶] [BZOJ]2127: happiness 最小割

    happiness: Description 高一一班的座位表是个n*m的矩阵,经过一个学期的相处,每个同学和前后左右相邻的同学互相成为了好朋友.这学期要分文理科了,每个同学对于选择文科与理科有着自己 ...

  4. bzoj 2127: happiness

    #include<cstdio> #include<iostream> #include<cstring> #define M 100009 #define inf ...

  5. BZOJ 2127 happiness ——网络流

    [题目分析] 基本上是第一次真正的使用最小割的模型. 同时加上一个数然后最后再减去是处理负数的一种方法. 设立出来最小割的模型然后解方程是一件很重要的事情,建议取一个相对来说比较简单的值带入求解. 这 ...

  6. bzoj 2127 happiness【最小割+dinic】

    参考:https://www.cnblogs.com/chenyushuo/p/5144957.html 不得不说这个建图方法真是非常妙啊 假设S点选理,T点选文,a[i][j]为(i,j)选文收益, ...

  7. BZOJ 2127: happiness(最小割解决集合划分)

    Time Limit: 51 Sec  Memory Limit: 259 MBSubmit: 2350  Solved: 1138[Submit][Status][Discuss] Descript ...

  8. BZOJ 2127 / Luogu P1646 [国家集训队]happiness (最小割)

    题面 BZOJ传送门 Luogu传送门 分析 这道题又出现了二元关系,于是我们只需要解方程确定怎么连边就行了 假设跟SSS分在一块是选文科,跟TTT分在一块是选理科,先加上所有的收益,再来考虑如何让需 ...

  9. [国家集训队]happiness 最小割 BZOJ 2127

    题目描述 高一一班的座位表是个n*m的矩阵,经过一个学期的相处,每个同学和前后左右相邻的同学互相成为了好朋友.这学期要分文理科了,每个同学对于选择文科与理科有着自己的喜悦值,而一对好朋友如果能同时选文 ...

随机推荐

  1. 希尔密码(Hill Cipher)的实现

    原理应该不用多讲了,自己百度就可以. C++实现: #include <iostream> #include <string> #include <memory.h> ...

  2. [hadoop]mapreduce原理简述

    1.用于map的输入,先将输入数据切分成相等的分片,为每一个分片创建一个map worker,这里的切片大小不是随意订的,一般是与HDFS块大小一致,默认是64MB,一个节点上存储输入数据切片的最大s ...

  3. 51nod 小Z的trie(Trie+广义SAM)

    [题目链接] http://www.51nod.com/contest/problem.html#!problemId=1647 [题意] 给定一个n个字符串的Trie,每次询问一个字符串在Trie上 ...

  4. 37、使用FileInputStream和FileOutputStream读取和写入

    绝对路径和相对路径 绝对路径:指文件在硬盘上真正存在的路径,比如:D:\Java\HelloWorld.java,这个指的是在电脑的d盘下的Java文件夹里面有个HelloWorld.java文件 相 ...

  5. 【codeforces】【比赛题解】#931 CF Round #468 (Div. 2)

    因为太迟了,所以没去打. 后面打了Virtual Contest,没想到拿了个rank 3,如果E题更快还能再高,也是没什么想法. [A]Friends Meeting 题意: 在数轴上有两个整点\( ...

  6. 【杂谈】需要mark的一些东西

    https://riteme.github.io/blog/2017-10-28/oi-coding-guidelines.html https://www.luogu.org/blog/34238/ ...

  7. 服务发现 consul cluster 的搭建

    consul cluster setup 介绍和指南: consul用于服务发现.当底层服务发生变化时,能及时更新正确的mysql服务IP. 并提供给业务查询.但需要自行编写脚本,监测数据库状态和切断 ...

  8. 读书笔记 effective c++ Item 19 像设计类型(type)一样设计类

    1. 你需要重视类的设计 c++同其他面向对象编程语言一样,定义了一个新的类就相当于定义了一个新的类型(type),因此作为一个c++开发人员,大量时间会被花费在扩张你的类型系统上面.这意味着你不仅仅 ...

  9. Intel大坑之一:丢失的SSE2 128bit/64bit 位移指令,马航MH370??

    缘由 最近在写一些字符串函数的优化,兴趣使然,可是写的过程中,想要实现 128bit 的按 bit 逻辑位移,遇到了一个大坑,且听我娓娓道来. 如果要追究标题,更确切的是丢失的SSE2 128 bit ...

  10. ASP .NET Core 2.0 MVC 发布到 IIS 上以后 无法下载apk等格式的文件

    ASP .NET Core MVC 发布到  IIS 上以后 无法下载apk等格式的文件 使用.NET Core MVC创建了一个站点,其他文件可以下载,但是后来又需求,就把手机端的apk合适的文件上 ...