题目链接 : https://ac.nowcoder.com/acm/contest/206/A

  这个题去年有幸去秦皇岛参加集训,见过这道题,当时特别菜还不会网络流,现在学了一点发现这个网络流还是比较简单的。

  首先题意要求价值根据蜡烛数量有变化,因为数据不大,我们可以每个点多联几条变,写成第一区域连接汇点

  区域到汇点的流量为1,费用为1,3,5,7.。。。。,因为从小到大加和,和正好为x的平方,所以的边流量都为1,因为只可以走一次,最后从原点到汇点跑个网络流就可以了

  AC代码 :

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<algorithm>
#include<iostream>
#include<math.h>
#include<vector>
#include<queue>
using namespace std;
#define INT_MAX 0x73f3f3f
typedef struct w_w{
int eend;
int weight;
int liu;
int next;
}miao;
miao x[];
int head[];
int cnt;
int money[];
int bian[];
int dian[];
int vis[];
queue<int> q1;
int spfa(int s,int e){
memset(bian,-,sizeof(bian));
memset(dian,-,sizeof(dian));
for(int i=;i<=;i++){
money[i]=INT_MAX;
}
money[e]=INT_MAX;
while(q1.size()) q1.pop();
q1.push(s);
money[s]=;
while(q1.size()){
int dang=q1.front();
//printf("%d\n",dang);
q1.pop();
vis[dang]=;
for(int i=head[dang];i!=-;i=x[i].next){
int to=x[i].eend;
int w=x[i].weight;
if(x[i].liu>&&money[dang]+w<money[to]){
money[to]=money[dang]+w;
if(vis[to]==) q1.push(to);
vis[to]=;
bian[to]=i;
dian[to]=dang;
//printf("%d %d %d\n",dang,i,to);
//system("pause");
}
}
}
if(money[e]!=INT_MAX) return ;
else return ;
}
void add(int s,int e,int l,int w){
x[cnt].eend=e;
x[cnt].weight=w;
x[cnt].liu=l;
x[cnt].next=head[s];
head[s]=cnt++;
}
int main()
{
int m,n;
scanf("%d %d",&m,&n);
memset(head,-,sizeof(head));
cnt=;
int start=;
int eend=;
for(int i=;i<=m;i++){
int a,b;
scanf("%d %d",&a,&b);
add(,n+i,,);
add(n+i,,,);
add(n+i,a,,);
add(a,n+i,,);
add(n+i,b,,);
add(b,n+i,,);
}
for(int i=;i<=n;i++){
for(int j=;j<n+;j++){
add(i,eend,,*j+);
add(eend,i,,-(*j+));
}
}
int sum=;
while(spfa(start,eend)){
//printf("+++\n");
int minn=INT_MAX;
for(int i=eend;i!=start;i=dian[i]){
int k=bian[i];
//printf("+++%d\n",i);
minn=min(minn,x[k].liu);
}
sum+=minn*money[eend];
for(int i=eend;i!=start;i=dian[i]){
int k=bian[i];
x[k].liu-=minn;
x[k^].liu+=minn;
//printf("%d\n",k);
}
}
printf("%d\n",sum);
return ;
}

牛客国庆day 6 A的更多相关文章

  1. 牛客国庆集训派对Day6 A Birthday 费用流

    牛客国庆集训派对Day6 A Birthday:https://www.nowcoder.com/acm/contest/206/A 题意: 恬恬的生日临近了.宇扬给她准备了一个蛋糕. 正如往常一样, ...

  2. 2019牛客国庆集训派对day5

    2019牛客国庆集训派对day5 I.Strange Prime 题意 \(P=1e10+19\),求\(\sum x[i] mod P = 0\)的方案数,其中\(0 \leq x[i] < ...

  3. 牛客国庆集训派对Day1 L-New Game!(最短路)

    链接:https://www.nowcoder.com/acm/contest/201/L 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 1048576K,其他语言20 ...

  4. 牛客国庆集训派对Day4 J-寻找复读机

    链接:https://www.nowcoder.com/acm/contest/204/J 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 1048576K,其他语言20 ...

  5. 牛客国庆集训派对Day4 I-连通块计数(思维,组合数学)

    链接:https://www.nowcoder.com/acm/contest/204/I 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 1048576K,其他语言20 ...

  6. 牛客国庆集训派对Day1-C:Utawarerumono(数学)

    链接:https://www.nowcoder.com/acm/contest/201/C 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 1048576K,其他语言20 ...

  7. 牛客国庆集训派对Day2 Solution

    A    矩阵乘法 思路: 1° 牛客机器太快了,暴力能过. #include <bits/stdc++.h> using namespace std; #define N 5000 in ...

  8. 平衡二叉树 (牛客国庆day2)解锁二叉树打表姿势&&找规律套路

    链接:https://www.nowcoder.com/acm/contest/202/F来源:牛客网 平衡二叉树,顾名思义就是一棵“平衡”的二叉树.在这道题中,“平衡”的定义为,对于树中任意一个节点 ...

  9. 牛客国庆集训day5 B 电音之王 (大数乘模)

    链接:https://www.nowcoder.com/acm/contest/205/B来源:牛客网 题目描述 终于活成了自己讨厌的样子. 听说多听电音能加快程序运行的速度. 定义一个数列,告诉你a ...

  10. 牛客国庆集训day6 B Board (模拟标记思维或找规律或分块???)

    链接:https://www.nowcoder.com/acm/contest/206/B来源:牛客网 题目描述 恬恬有一个nx n的数组.她在用这个数组玩游戏: 开始时,数组中每一个元素都是0. 恬 ...

随机推荐

  1. 7-----Scrapy框架中Download Middleware用法

    这篇文章中写了常用的下载中间件的用法和例子.Downloader Middleware处理的过程主要在调度器发送 requests请求的时候以及网页将 response结果返回给 spiders的时候 ...

  2. c++ 封装线程库 3

    1. 继承与重写run方法 我们封装了Thread类,并设置成员函数run()为纯虚函数,因此我们使用类继承,并重写run方法: class IncCount : public Thread//增加计 ...

  3. AVplayer搭建ftp共享PC端

    1.安装FTP服务 2.关闭防火墙 3.添加FTP站点 设置ip时,需要查询本机的ip 本机测试 4.iphone安装AVPlayer,并设置

  4. linux 安装dubbo+zookeeper

    dubbo+zookeeper 启动成功 注意:dubbo-admin-2.5.4 不支持java8

  5. vue中遇到的坑

    如何解决在vue中替换图片.一个使用base64,而我们使用zepto之后,src找不到资源,因为已经打包了,难道强行写base64. 1. 引入文件时语法很重要! import "Foot ...

  6. Linux禁ping

    A.临时允许PING操作的命令为:# >/proc/sys/net/ipv4/icmp_echo_ignore_all B.永久允许PING配置方法. /etc/sysctl.conf 中增加一 ...

  7. HDU 2255 ——奔小康赚大钱——————【KM算法裸题】

    奔小康赚大钱 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Statu ...

  8. Spring Data JPA 事务

    Spring Data JPA 是 Spring 基于 ORM 框架.JPA 规范的基础上封装的一套 JPA 应用框架,可使开发者用极简的代码即可实现对数据的访问和操作.它提供了包括增删改查等在内的常 ...

  9. jsp---tomcat===》》内置对象

    1.内置对象:    request: 方法:getParameter("txtName"):获取和页面上的name属性对象的value值       返回String       ...

  10. intellijidea课程 intellijidea神器使用技巧1-5 idea界面介绍

    菜单栏介绍: file:文件操作edit:文本操作view:视图操作navigate:跳转code:源码文件analyze:项目依赖关系分析refactor:代码重构快捷操作,如:抽取函数build: ...