题意:

      以一些科目,和辅导班,每个科目最终要求修到某个等级,可以花一定的钱在辅导班把某一科目修到某一等级,进入辅导班的时候会有一个限制,那就是达到他给出的科目和等级限制,比如a b c d m的意思就是科目a必须达到b等级才可以花m钱把科目c修到d等级,最后问把所有科目修到给定的等级要花的最小辅导费用。

思路:

      我们可以把每一个科目的每一个等级看成一个点,然后根据给定的关系,把等级和等级之间的边和权建立起来,然后再把非0等级建一条当前等级-1的边,费用为0,意思是修了当前等级,之前的等级也算是修完了,最后在虚拟出来一个点,连接所有等级0的点,意思是最开始0等级的已经修完了,然后一遍最小树形图就行了,对于最小树形图,他其实就是在求有向图的最小生成树,用的是 朱-刘 算法(我自己现在还不了解那个算法,只是直接粘模板而已,自己一直感觉不到这个算法的正确性)。


#include<stdio.h>
#include<string.h> //******************************************
const int maxm=2000000; //边的个数
const int maxn=25100; //点的个数
const int inf=0x3f3f3f3f; typedef struct
{
int
u,v,w;
}
EDGE;
EDGE e[maxm];
int
pre[maxn],id[maxn],vis[maxn],in[maxn];
typedef struct
{
int
directedMST(int root ,int n ,int m)
{
//从0开始用的 0....N,m条边
int res=0,nv=n + 1,i;
while (
1)
{
for (
i=0;i<nv;i++)
{

in[i]=inf;
}
for (
i=1;i<=m;i++)
{
int
u=e[i].u;
int
v=e[i].v;
if (
e[i].w<in[v]&&u!=v)
{

pre[v]=u;
in[v]=e[i].w;
}
}
for (
i=0;i<nv;i++)
{
if (
i==root)continue;
if (
in[i]==inf)return -1;
}
int
cntnode=0;
memset(id,-1,sizeof(id[0])*(nv+3));
memset(vis,-1,sizeof(vis[0])*(nv+3));
in[root]=0;
for (
i=0;i<nv;i++)
{

res+=in[i];
int
v=i;
while (
vis[v]!=i&&id[v]==-1&&v!=root)
{

vis[v]=i;
v=pre[v];
}
if (
v!=root&&id[v]==-1)
{
for (int
u=pre[v];u!=v;u=pre[u])
{

id[u]=cntnode;
}

id[v]=cntnode++;
}
}
if (
cntnode==0)break;
for (
i=0;i<nv;i++)
{
if (
id[i]==-1)id[i]=cntnode++;
}
for (
i=1;i<=m;i++)
{
int
v=e[i].v;
e[i].u=id[e[i].u];
e[i].v=id[e[i].v];
if (
e[i].u!=e[i].v)
{

e[i].w-=in[v];
}
}

nv=cntnode;
root=id[root];
}
return
res;
}
}
M_Tree;
//***************************************
int sum[55];
int
num[55]; int main ()
{
int
n ,m ,i ,j;
int
a ,b ,c ,d ,mo;
M_Tree T;
while(~
scanf("%d %d" ,&n ,&m) && n + m)
{

sum[0] = 0;
for(
i = 1 ;i <= n ;i ++)
{

scanf("%d" ,&num[i]);
num[i] ++;
sum[i] = sum[i-1] + num[i];
}
int
tt = 0;
while(
m--)
{

scanf("%d %d %d %d %d" ,&a ,&b ,&c ,&d ,&mo);
b++ ,d ++;
for(int
i = sum[a-1] + b ;i <= sum[a] ;i ++)
{

e[++tt].u = i;
e[tt].v = sum[c-1] + d;
e[tt].w = mo;
}
}
for(
i = 1 ;i <= n ;i ++)
{
for(
j = sum[i-1] + 2 ;j <= sum[i] ;j ++)
{

e[++tt].u = j;
e[tt].v = j-1;
e[tt].w = 0;
}

e[++tt].u = 0;
e[tt].v = sum[i-1] + 1;
e[tt].w = 0;
}

printf("%d\n",T.directedMST(0 ,sum[n] ,tt));
}
return
0;
}

hdu4966 最小树形图(最少辅导花费)的更多相关文章

  1. hdu4966 最小树形图+虚根

    /* 辛辛苦苦调试半天, 过了样例,竟然没有ac!! 网上对比了ac代码,感觉添加一个虚根就能ac 但是想不明白为什么 */ /* 第二天想了下,知道了为什么wa:因为从等级0连到其他课程等级i的不止 ...

  2. 最小树形图(hdu4966多校联赛9)

    GGS-DDU Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) Total ...

  3. HDU4966 GGS-DDU(最小树形图)

    之前几天想着补些算法的知识,学了一下最小树形图的朱刘算法,不是特别理解,备了份模板以备不时之需,想不到多校冷不丁的出了个最小树形图,没看出来只能表示对算法不太理解吧,用模板写了一下,然后就过了.- - ...

  4. HDU 4966 GGS-DDU(最小树形图)

    n个技能,每个技能有0-a[i]的等级,m个课程,每个课程需要前置技能c[i]至少达到lv1[i]等级,效果是技能d[i]达到lv2[i]等级,花费w[i]. 输出最小花费使得全技能满级(初始全技能0 ...

  5. hdu3072 强连通+最小树形图

    题意:有一个人他要把一个消息通知到所有人,已知一些通知关系:A 能通知 B,需要花费 v,而又知道,如果某一个小团体,其中的成员相互都能直接或间接通知到,那么他们之间的消息传递是不需要花费的,现在问这 ...

  6. UVA 11865 Stream My Contest(最小树形图)

    题意:N台机器,M条有向边,总资金C,现要到搭建一个以0号机(服务器)为跟的网路,已知每条网线可以把数据从u传递到v,其带宽为d,花费为c,且d越大,传输速度越快,问能够搭建的传输速度最快的网络d值是 ...

  7. 【UVA 11865】 Stream My Contest (二分+MDST最小树形图)

    [题意] 你需要花费不超过cost元来搭建一个比赛网络.网络中有n台机器,编号0~n-1,其中机器0为服务器,其他机器为客户机.一共有m条可以使用的网线,其中第i条网线的发送端是机器ui,接收端是机器 ...

  8. UVA 6199 不定根最小树形图

    首先是最小树形图的介绍. 看这个博客.最小树形图 上面介绍的很详细了,我就讲一下这道题的题意. 首先给出一些二维点坐标,这些坐标之间构成一些有向图,根据题意,假设两个点a(x1 ,y1) ,b(x2 ...

  9. bzoj2260: 商店购物 && 4349: 最小树形图

    Description Grant是一个个体户老板,他经营的小店因为其丰富的优惠方案深受附近居民的青睐,生意红火.小店的优惠方案十分简单有趣.Grant规定:在一次消费过程中,如果您在本店购买了精制油 ...

随机推荐

  1. 七. SpringCloud服务配置

    1. SpringCloud Config概述 1.1 分布式系统面临的配置问题 微服务意味着要将单体应用中的业务拆分成一个一个子服务,每个服务的粒度相对较小,因此系统中会出现大量的服务.由于每个服务 ...

  2. Python Flask框架路由简单实现

    Python Flask框架路由的简单实现 也许你听说过Flask框架.也许你也使用过,也使用的非常好.但是当你在浏览器上输入一串路由地址,跳转至你所写的页面,在Flask中是怎样实现的,你是否感到好 ...

  3. MongoDB -> kafka 高性能实时同步(sync 采集)mongodb数据到kafka解决方案

    写这篇博客的目的 让更多的人了解 阿里开源的MongoShake可以很好满足mongodb到kafka高性能高可用实时同步需求(项目地址:https://github.com/alibaba/Mong ...

  4. 从零学脚手架(二)---初识webpack

    在上一篇中,介绍了 webpack 的 entry . output . plugins 属性. 在这一篇,接着介绍其它配置属性. mode 这个属性在上一篇中使用过一次:设置 webpack 编译模 ...

  5. 死磕Spring之IoC篇 - @Bean 等注解的实现原理

    该系列文章是本人在学习 Spring 的过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring 源码分析 GitHub 地址 进行阅读 Spring 版本:5.1. ...

  6. ClickHouse元数据异常-MySQLHandlerFactory:Failed to read RSA key pair from server

    Clickhouse版本:20.3.6.40-2 clickhouse集群三个节点,一分片,三副本,三个节点数据完全一样 1. 问题描述 在使用连接工具操作时,发现其中一个节点连接拒绝,无法操作,另外 ...

  7. BeetleX使用bootstrap5开发SPA应用

        在早期版本BeetleX.WebFamily只提供了vuejs+element的集成,由于element只适合PC管理应用开发相对于移动应用适配则没这么方便.在新版本组件集成了bootstra ...

  8. 【odoo14】第四章、应用模型

    由于本章有包含很多基础知识,个人不会全部转化为自己的语言.直接机器翻译了(用斜体标注,机器翻译反而一字不落,我会过滤掉冗余的内容),虽然机翻,但会保证意思不会偏. 本章主要章节如下: 定义模型展示及顺 ...

  9. Gevent高并发网络库精解

    进程 线程 协程 异步 并发编程(不是并行)目前有四种方式:多进程.多线程.协程和异步. 多进程编程在python中有类似C的os.fork,更高层封装的有multiprocessing标准库 多线程 ...

  10. 【wp】2021V&NCTF

    前几天打完的V&NCTF公开赛,做题的时候没记过程,这是复现wp. 最后排名Top 18,三道RE+两道杂项(wp没啥可放的hhh)+一道web,感觉re题目还是挺好的,难度适中点赞,尤其pc ...