P4297 [NOI2006]网络收费

题目背景

noi2006 day1t1

题目描述

网络已经成为当今世界不可或缺的一部分。每天都有数以亿计的人使用网络进行学习、科研、娱乐等活动。然而,不可忽视的一点就是网络本身有着庞大的运行费用。所以,向使用网络的人进行适当的收费是必须的,也是合理的。

MY 市NS 中学就有着这样一个教育网络。网络中的用户一共有 2^N2N 个,编号依次为1, 2, 3, …, 2^N2N 。这些用户之间是用路由点和网线组成的。用户、路由点与网线共同构成一个满二叉树结构。树中的每一个叶子结点都是一个用户,每一个非叶子结点(灰色)都是一个路由点,而每一条边都是一条网线(见下图,用户结点中的数字为其编号)。

MY 网络公司的网络收费方式比较奇特,称为“ 配对收费 ”。即对于每两个用户i, j (1≤i < j ≤ 2^N2N ) 进行收费。由于用户可以自行选择两种付费方式A、B中的一种,所以网络公司向学校收取的费用与每一位用户的付费方式有关。该费用等于每两位不同用户配对产生费用之和。

为了描述方便,首先定义这棵网络树上的一些概念:

  • 祖先:根结点没有祖先,非根结点的祖先包括它的父亲以及它的父亲的祖先;

  • 管辖叶结点:叶结点本身不管辖任何叶结点,非叶结点管辖它的左儿子所管辖的叶结点与它的右儿子所管辖的叶结点;

  • 距离:在树上连接两个点之间的用边最少的路径所含的边数。

对于任两个用户i, j (1≤i<j≤ 2^N2N ),首先在树上找到与它们距离最近的公共祖先:路由点P,然后观察P 所管辖的叶结点(即用户)中选择付费方式A 与B的人数,分别记为nA 与nB,接着按照网络管理条例第X 章第Y 条第Z 款进行收费(如下表),其中 F_{i,j}Fi,j​ 为i 和j 之间的流量,且为已知量。

由于最终所付费用与付费方式有关,所以NS 中学的用户希望能够自行改变自己的付费方式以减少总付费。然而,由于网络公司已经将每个用户注册时所选择的付费方式记录在案,所以对于用户i,如果他/她想改变付费方式(由A 改为B 或由B 改为A),就必须支付 C_iCi​ 元给网络公司以修改档案(修改付费方式记录)。

现在的问题是,给定每个用户注册时所选择的付费方式以及 C_iCi​ ,试求这些用户应该如何选择自己的付费方式以使得NS 中学支付给网络公司的总费用最少(更改付费方式费用+配对收费的费用)。

输入输出格式

输入格式:

输入文件中第一行有一个正整数N。

第二行有 2^N2N 个整数,依次表示1 号,2 号,…, 2^N2N 号用户注册时的付费方式,每一个数字若为0,则表示对应用户的初始付费方式为A,否则该数字为1,表示付费方式为B。

第三行有 2^N2N 个整数,表示每一个用户修改付费方式需要支付的费用,依次为 C_1C1​ , C_2C2​ , …, C_MCM​ 。( M= 2^N2N )

以下 2^N2N -1 行描述给定的两两用户之间的流量表F,总第(i + 3)行第j 列的整数为 F_{i, j+i}Fi,j+i​ 。(1≤i< 2^N2N ,1≤j≤ 2^N2N – i)

所有变量的含义可以参见题目描述。

输出格式:

你的程序只需要向输出文件输出一个整数,表示NS 中学支付给网络公司的最小总费用。(单位:元)

输入输出样例

输入样例#1: 复制

2
1 0 1 0
2 2 10 9
10 1 2
2 1
3
输出样例#1: 复制

8

说明

【样例说明】

将 1 号用户的付费方式由B 改为A,NS 中学支付给网络公司的费用达到最小。

40%的数据中N≤4;

80%的数据中N≤7;

100%的数据中N≤10,0≤Fi, j≤500,0≤C_iCi​≤500 000。

#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 1050
using namespace std;
int n,N,map[maxn][maxn],c[maxn],fa[maxn][maxn],ans=0x7fffffff,sum;
int cnt[maxn][];
int a[maxn];
int father[];
void make(int sta){
for(int i=;i<=n;i++)
if(sta&(<<i-))
a[i]^=,sum+=c[i];
}
int work(){
memset(cnt,,sizeof(cnt));
int s=;
for(int i=;i<N;i++)s+=<<i;
for(int i=;i<=n;i++){
if(a[i]==)cnt[i+s][]++;
else cnt[i+s][]++;
}
for(int i=s;i>=;i--){
cnt[i][]+=cnt[i*][]+cnt[i*+][];
cnt[i][]+=cnt[i*][]+cnt[i*+][];
}
for(int i=;i<=n;i++)
for(int j=i+;j<=n;j++){
int f=fa[i][j];
if(cnt[f][]<cnt[f][]){
if(a[i]==&&a[j]==)sum+=*map[i][j];
if(a[i]^a[j])sum+=map[i][j];
}
else {
if(a[i]==&&a[j]==)sum+=*map[i][j];
if(a[i]^a[j])sum+=map[i][j];
}
}
}
void findfather(){
int s=;
for(int i=;i<N;i++)s+=<<i;
for(int i=;i<=(<<N);i++)
for(int j=i+;j<=(<<N);j++){
int a1=s+i,a2=s+j;
while(a1!=a2)a1=father[a1],a2=father[a2];
fa[i][j]=a1;
}
}
int main(){
scanf("%d",&N);
n=<<N;
for(int i=;i<=(<<N);i++)
father[i*]=i,father[i*+]=i;
findfather();
for(int i=;i<=n;i++)scanf("%d",&a[i]);
for(int i=;i<=n;i++)scanf("%d",&c[i]);
for(int i=;i<n;i++)
for(int j=i+;j<=n;j++)
scanf("%d",&map[i][j]);
for(int sta=;sta<(<<n);sta++){
sum=;
make(sta);work();
ans=min(ans,sum);
make(sta);
}
printf("%d",ans);
return ;
}

40分 暴力

#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 1030
using namespace std;
int n,m,a[maxn],t[maxn];
long long c[maxn],w[maxn][maxn],v[maxn][maxn],f[maxn<<][maxn];
void make(int x,int d){
if(!d)return;
make(x<<,d-);make(x<<|,d-);
for(int i=x<<d;i<((x<<)+)<<(d-);i++)
for(int j=((x<<)+)<<(d-);j<(x+)<<d;j++)
v[i-m][x]+=w[i-m][j-m],
v[j-m][x]+=w[i-m][j-m];
}
void dfs(int x,int d){
if(!d){
f[x][a[x-m]]=;
f[x][a[x-m]^]=c[x-m];
for(int i=x>>;i;i>>=)f[x][t[i]]+=v[x-m][i];
return;
}
memset(f[x],0x3f,sizeof(f[x]));
t[x]=;
dfs(x<<,d-);dfs(x<<|,d-);
for(int i=;i<=<<(d-);i++)
for(int j=;j<=(<<(d-))-i;j++)
f[x][i+j]=min(f[x][i+j],f[x<<][i]+f[x<<|][j]);
t[x]=;
dfs(x<<,d-);dfs(x<<|,d-);
for(int i=;i<=<<(d-);i++)
for(int j=(<<(d-))-i+;j<=<<(d-);j++)
f[x][i+j]=min(f[x][i+j],f[x<<][i]+f[x<<|][j]);
}
int main(){
long long ans=1LL<<;
scanf("%d",&n);m=<<n;
for(int i=;i<m;i++) scanf("%d",&a[i]);
for(int i=;i<m;i++) scanf("%lld",&c[i]);
for(int i=;i<m;i++)
for(int j=i+;j<m;j++)
scanf("%lld",&w[i][j]);
make(,n);
dfs(,n);
for(int i=;i<=m;i++)ans=min(ans,f[][i]);
printf("%lld",ans);
return ;
}

100分 树形背包(还没看懂)

洛谷 P4297 [NOI2006]网络收费的更多相关文章

  1. 【简】题解 P4297 [NOI2006]网络收费

    传送门:P4297 [NOI2006]网络收费 题目大意: 给定一棵满二叉树,每个叶节点有一个状态(0,1),任选两个叶节点,如果这两个叶节点状态相同但他们的LCA所管辖的子树中的与他们状态相同的叶节 ...

  2. 5.21 省选模拟赛 luogu P4297 [NOI2006]网络收费 树形dp

    LINK:网络收费 还是自己没脑子. 早上思考的时候 发现树形dp不可做 然后放弃治疗了. 没有合理的转换问题的模型是我整个人最大的败笔. 暴力也值得一提 爆搜之后可以写成FFT的形式的计算贡献的方法 ...

  3. 洛谷 P1546 最短网络 Agri-Net

    题目链接 https://www.luogu.org/problemnew/show/P1546 题目背景 农民约翰被选为他们镇的镇长!他其中一个竞选承诺就是在镇上建立起互联网,并连接到所有的农场.当 ...

  4. 【BZOJ1495】[NOI2006]网络收费 暴力+DP

    [BZOJ1495][NOI2006]网络收费 Description 网络已经成为当今世界不可或缺的一部分.每天都有数以亿计的人使用网络进行学习.科研.娱乐等活动.然而,不可忽视的一点就是网络本身有 ...

  5. BZOJ_1495_[NOI2006]网络收费_树形DP

    BZOJ_1495_[NOI2006]网络收费_树形DP Description 网络已经成为当今世界不可或缺的一部分.每天都有数以亿计的人使用网络进行学习.科研.娱乐等活动.然而, 不可忽视的一点就 ...

  6. 并不对劲的[noi2006]网络收费

    题目略长,就从大视野上复制了. 听上去好像费用流,然而…… ***************************表示略长的题目的分界线************************ 1495: [ ...

  7. 洛谷P1546 最短网络 Agri-Net(最小生成树,Kruskal)

    洛谷P1546 最短网络 Agri-Net 最小生成树模板题. 直接使用 Kruskal 求解. 复杂度为 \(O(E\log E)\) . #include<stdio.h> #incl ...

  8. 洛谷P2812校园网络【Network of Schools加强版】

    题目背景 浙江省的几所\(OI\)强校的神犇发明了一种人工智能,可以\(AC\)任何题目,所以他们决定建立一个网络来共享这个软件.但是由于他们脑力劳动过多导致全身无力身体被\(♂\)掏\(♂\)空,他 ...

  9. 【题解】洛谷P1262 间谍网络 (强连通分量缩点)

    洛谷P1262:https://www.luogu.org/problemnew/show/P1262 思路 一看题目就知道是强连通分量缩点 当图中有强连通分量时 将其缩点 我们可以用dfn数组判断是 ...

随机推荐

  1. Spring 学习一 @Autowired

    @Autowired Spring 2.5 引入了 @Autowired ,它可以对类成员变量.方法及构造函数进行标注,完成自动装配的工作. 通过 @Autowired的使用来消除 set ,get方 ...

  2. 监控和安全运维 1.5 nagios监控客户端-1

    3. Nagios安装 - 客户端(192.168.0.12)在客户端机器上 rpm -ivh http://www.aminglinux.com/bbs/data/attachment/forum/ ...

  3. css垂直居中方法(二)

    第四种方法: 这个方法把一些div的显示方式设置为表格,因此我们可以使用表格的vartial-align属性. 代码如下: <!doctype html> <html lang=&q ...

  4. close、flush、read、readline、seek、tell、truncate、write的使用

    1.close关闭文件 f1= open("ha.log","r+",encoding="utf-8") data = f1.read() ...

  5. TCP UDP HTTP 的关系和区别

    TCP UDP HTTP 三者的关系: TCP/IP是个协议组,可分为四个层次:网络接口层.网络层.传输层和应用层. 在网络层有IP协议.ICMP协议.ARP协议.RARP协议和BOOTP协议. 在传 ...

  6. solr笔记--solr3.2以后支持document和json两种对象来更新索引

    1.json形式(比如把mongodb数据库的导出结果json) <requestHandler name="/update" class="solr.JsonUp ...

  7. 4-4 zk特性 – 理解watcher机制

    watcher是zk里面非常重要的特性.watcher一定要去好好地看一下,一定要去好好地理解一下它是如何去用的,包括触发的事件类型等等.监督者也可以理解为触发器,也就是说当我们的节点发生了一些变化的 ...

  8. day17-jdbc 4.DriverManager详解

    我们找的不是J2EE的API,因为JDBC不在web程序用也可以,纯java也能玩.所以jdbc的api在java se那里,或者说是在jdk那里. DriverManger它底层有一个集合是一个Ve ...

  9. HDU 6162 树链剖分

    题意:给你一颗树,每个节点有有一个权值,每次询问从x到y的最短路上权值在c到d之间的所有的点的权值和是多少. 思路:肯定要用树剖,因为询问c到d之间这种操作树上倍增很难做,但是用其它数据结构可以比较好 ...

  10. ROS Learning-027 (提高篇-005 A Mobile Base-03) 控制移动平台 --- Twist 消息

    ROS 提高篇 之 A Mobile Base-03 - 控制移动平台 - Twist 消息 我使用的虚拟机软件:VMware Workstation 11 使用的Ubuntu系统:Ubuntu 14 ...