[IOI2007]训练路径
Description
Input
Output
Sample Input
2 1 0
3 2 0
4 3 0
5 4 0
1 3 2
3 5 2
2 4 5
2 5 1
Sample Output
HINT
首先如果一条边的两个点在树上的路径长度为奇数,那么这条边肯定要删掉。
那么我们可以发现,这时存在偶环的充要条件就是一个环经过了任意两条非树边。
因为两个奇环通过公共边拼在一起,再把公共边挖掉,肯定是一个偶环。
所以这道题的限制就是不能出现这种情况,也就是说我们需要留下一棵仙人掌。
转化一下,改为求总边权减去最大留下的边权
于是定义$f[i][S]$表示i点,不考虑S集合的儿子
对于一个以i为LCA的非树边,如果都不留
那么$f[i][S]=∑f[son][0]*[S不含son]$
如果要选择边(u,v),那么u->i和v->i上不能与其他非树边形成的环有公共边
答案由三部分组成:
1.u和v的子树,无限制,取$f[u][0]$,$f[v][0]$
2.u(或v)->i路径上求出每个点不考虑它到u(或v)的儿子的方案和
$\sum_{a=u}f[a][S]$
S为不考虑该点到u(或v)
3.i点不考虑到u的儿子son1,到v的儿子son2
$f[i][S]$ S为没有考虑son1和son2的状态
复杂度$O(m*2^{10}+m*n)$
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
using namespace std;
typedef long long lol;
struct Edge
{
int u,v,d;
}e[];
struct Node
{
int next,to;
}edge[];
vector<int>h[];
int f[][],son[],n,m,ans,LCA;
int top[],head[],num,tot,dep[],dfn[],idf[],id[],fa[],size[];
void add(int u,int v)
{
num++;
edge[num].next=head[u];
head[u]=num;
edge[num].to=v;
}
void dfs1(int x,int pa)
{int i;
fa[x]=pa;
size[x]=;
dep[x]=dep[pa]+;
for (i=head[x];i;i=edge[i].next)
{
int v=edge[i].to;
if (v==pa) continue;
dfs1(v,x);
size[x]+=size[v];
if (size[v]>size[son[x]]) son[x]=v;
}
}
void dfs2(int x,int pa,int tp)
{int i;
top[x]=tp;
if (son[x]) dfs2(son[x],x,tp);
for (i=head[x];i;i=edge[i].next)
{
int v=edge[i].to;
if (v==pa||v==son[x]) continue;
dfs2(v,x,v);
}
}
int get_lca(int x,int y)
{
while (top[x]!=top[y])
{
if (dep[top[x]]<dep[top[y]]) swap(x,y);
x=fa[top[x]];
}
if (dep[x]<dep[y])
return x;
else return y;
}
void DP(int x,int pa)
{int i,sum,j,p,u,v,cnt=;
for (i=head[x];i;i=edge[i].next)
{
int v=edge[i].to;
if (v==pa) continue;
DP(v,x);
}
cnt=;
for (i=head[x];i;i=edge[i].next)
{
int v=edge[i].to;
if (v!=pa) id[cnt]=v,idf[v]=<<cnt,cnt++;
}
for (i=;i<=(<<cnt)-;i++)
{sum=;
for (j=;j<cnt;j++)
if (!(i>>j&))
{
sum+=f[id[j]][];
}
f[x][i]=sum;
}
int ed=h[x].size();
for (p=;p<=ed-;p++)
{
i=h[x][p];u=;v=;
sum=e[i].d;
if (e[i].u!=x)
sum+=f[e[i].u][];
if (e[i].v!=x)
sum+=f[e[i].v][];
if (e[i].u!=x)
for (u=e[i].u;fa[u]!=x;u=fa[u])
sum+=f[fa[u]][idf[u]];
if (e[i].v!=x)
for (v=e[i].v;fa[v]!=x;v=fa[v])
sum+=f[fa[v]][idf[v]];
for (j=;j<=(<<cnt)-;j++)
if ((j&idf[u])==&&(j&idf[v])==)
{
f[x][j]=max(f[x][j],f[x][j|idf[u]|idf[v]]+sum);
}
}
}
int main()
{int i,u,v,d;
//freopen("zyys.in","r",stdin);
//freopen("zyys.out","w",stdout);
cin>>n>>m;
for (i=;i<=m;i++)
{
scanf("%d%d%d",&u,&v,&d);
if (!d) add(u,v),add(v,u);
else e[++tot].u=u,e[tot].v=v,e[tot].d=d,ans+=d;
}
dfs1(,);dfs2(,,);
for (i=;i<=tot;i++)
{
LCA=get_lca(e[i].u,e[i].v);
if ((dep[e[i].u]+dep[e[i].v]-*dep[LCA])%==)
h[LCA].push_back(i);
}
DP(,);
cout<<ans-f[][];
}
[IOI2007]训练路径的更多相关文章
- bzoj1808 [Ioi2007]training 训练路径
Description 马克(Mirko)和斯拉夫克(Slavko)正在为克罗地亚举办的每年一次的双人骑车马拉松赛而紧张训练.他们需要选择一条训练路径. 他们国家有N个城市和M条道路.每条道路连接两个 ...
- 使用SSD检测框架训练自己的数据
数据集做好后,训练程序为/examples/ssd/ssd_pascal.py,运行之前,我们需要修改相关路径代码,主要是训练路径的修改和关于自己数据集参数的一些修改. cd /examples/ss ...
- K210,yolo,face_mask口罩检测模型训练及其在K210,kd233上部署
前段时间考研,再加上工作,时间很紧,一直没有更新博客,这几天在搞k210的目标检测模型,做个记录,遇到问题可以添加qq522414928或添加微信13473465975,共同学习 首先附上github ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- NOIP前的刷题记录
因为这几天要加油,懒得每篇都来写题解了,就这里记录一下加上一句话题解好了 P4071 [SDOI2016]排列计数 组合数+错排 loj 6217 扑克牌 暴力背包 P2511 [HAOI2008 ...
- 树形dp专题总结
树形dp专题总结 大力dp的练习与晋升 原题均可以在网址上找到 技巧总结 1.换根大法 2.状态定义应只考虑考虑影响的关系 3.数据结构与dp的合理结合(T11) 4.抽直径解决求最长链的许多类问题( ...
- noi前机房日常
2015/6/16 上午a了一道省选分组赛day1t2,并在cf100553H双倍经验,好评 bzoj3152(ctsc2013)贪心,用priority_queue要清空 bx2k上午交了几十题,他 ...
- noip模拟赛(一)宠物之战
宠物之战 (senso.pas/c/cpp) [问题描述] 众所周知,moreD的宠物已经被moreD奴役得体无完肤.这只宠物实在忍无可忍,把自己每天走魔法树的经历告诉了自己的宠物.同时他还说明了自己 ...
- batch gradient descent(批量梯度下降) 和 stochastic gradient descent(随机梯度下降)
批量梯度下降是一种对参数的update进行累积,然后批量更新的一种方式.用于在已知整个训练集时的一种训练方式,但对于大规模数据并不合适. 随机梯度下降是一种对参数随着样本训练,一个一个的及时updat ...
随机推荐
- 【Spring源码深度解析学习系列】核心类介绍(一)
一.DefaultListableBeanFactory 首先看一下结构 由图可知XmlBeanFactory继承自DefaultListableBeanFactory,而DefaultListabl ...
- 【Redis使用系列】redis设置登陆密码
找到安装redis的配置文件,找到redis.comf文件找到#requirepass foobared 新建一行 requirepass xxxx 你的密码 ,然后重启.再登录的时候可以登录,但是 ...
- 记录python接口自动化测试--unittest框架基本应用(第二目)
在第一目里写了几个简单demo,并把调用get和post请求的方法封装到了一个类里,这次结合python自带的unittest框架,用之前封装的方法来写一个接口测试demo 1.unittest简单用 ...
- 多种在线地图综合对比,Google,必应,arcgis Online...
不同网络地图的对比 天地图 坐标系:WGS84 地图配色: POI数量:丰富 有无建筑:有 地图特点:天地图按照国家标准进行配图,道路.水系.植被等图层用对应颜色渲染, POI信息丰富, ...
- javascript 腾讯ABS云平台面试题及面试经历
既然说到面试前端肯定是Javascript各种问,只好各种答. 面试题肯定离不了,最近热门的Vue.js,React.js,Angular.js,Gulp,Webpack还有各种Js问题,还有令人头痛 ...
- requestAnimationFrame Web中写动画的另一种选择
HTML5和CSS3盛行的今天 动画变得很简单实现 我们可以用transition . animation + keyframe .也可以用canvas等 我在上一篇 点击回到顶部的文章中发现的这个 ...
- C语言Linix服务器网络爬虫项目(二)项目设计和通过一个http请求抓取网页的简单实现
我们通过上一篇了解了爬虫具体要实现的工作之后,我们分析得出的网络爬虫的基本工作流程如下: 1.首先选取一部分精心挑选的种子URL: 2.将这些URL放入待抓取URL队列: 3.从待抓取URL队列中取出 ...
- machine learning 之 导论 一元线性回归
整理自Andrew Ng 的 machine learnig 课程 week1. 目录: 什么是机器学习 监督学习 非监督学习 一元线性回归 模型表示 损失函数 梯度下降算法 1.什么是机器学习 Ar ...
- HDFS文件读写操作(基础基础超基础)
环境 OS: Ubuntu 16.04 64-Bit JDK: 1.7.0_80 64-Bit Hadoop: 2.6.5 原理 <权威指南>有两张图,下次po上来好好聊一下 实测 读操作 ...
- python全栈开发-logging模块(日记专用)
一.概述 很多程序都有记录日志的需求,并且日志中包含的信息即有正常的程序访问日志,还可能有错误.警告等信息输出,python的logging模块提供了标准的日志接口,你可以通过它存储各种格式的日志,l ...