临近\(noip,AK\)不太现实,暴力才是王道,大佬无视

这里只介绍\(65\)分做法



\(m==1\) 的情况

很明显 就一条路径,当然要贪心选着一条路径路上的最大的边喽

傻逼分\(get 20\)分



\(n,m<=100\)

想怎么暴力怎么暴力,反正不会TLE

**枚举割哪一条边 **

枚举每条路径dfs()一边 寻找最大值

最后取min 就好了

复杂度\(O(n^3)\)

又get 10分

很明显的二分,我就是不会(⊙o⊙)



一条链子的时候并且n<=3000

求路径的和的时候可以用前缀和维护一下

达到O(1)的查询

使得②的复杂度降低了一个\(O(n)\)

最终复杂的\(O(n^2)\)

get 15分 啦



一条链子的时候并且n>=3000

二分他的最大长度

当然得利用③的O(1)查询啦

考虑check函数

如果第i次运货路线大于x(也就是二分的mid)

那么要割掉的点一定在\(l_{i}\)和\(r_{i}\)之间

维护一下左边界和右边界就好了(如果不成立的话直接return 0)

最后在左边界和右边界查询最大就好啦

最终复杂度O(\(nlogn\))

get 20分

最终得分 \(65\)

打死我也不会lca

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int maxn=100007;
int n,m;
int S[maxn],T[maxn],num[maxn];
int noip[maxn],cz[maxn];
struct edge{
int v,nxt,q;
}e[maxn<<1];
int head[maxn<<1],tot;
int a[maxn],sum[maxn];
int tot_30,max_30,flag_30;
void add_edge(int u,int v,int q)
{
e[++tot].v=v;
e[tot].q=q;
e[tot].nxt=head[u];
head[u]=tot;
}
inline int read()
{
int x=0,f=1;char s=getchar();
while(s<'0'||s>'9') {if(s=='-')f=-1;s=getchar();}
while(s>='0'&&s<='9') {x=x*10+s-'0',s=getchar();}
return x*f;
}
void dfs_30(int u,int f,int end)
{
if(u==end) {
flag_30=1;
return;
}
for(int i=head[u];i;i=e[i].nxt)
{
int v=e[i].v;
if(v==f) continue; int tmp=max_30;
tot_30+=e[i].q;
max_30=max(max_30,e[i].q); dfs_30(v,u,end);
if(flag_30) return; tot_30-=e[i].q;
max_30=tmp;
}
}
int check(int x)
{
int l=1,r=n;
int zz=0;
for(int i=1;i<=m;++i)
{
if(num[i] > x)
{
zz=max(zz,num[i]);
if(l >= T[i]) return 0;
if(r <= S[i]) return 0;
l=max(l,S[i]);
r=min(r,T[i]);
}
}
int tmp=0;
for(int i=l+1;i<=r;++i)
tmp=max(tmp,a[i]);
zz-=tmp;
return zz > x ? 0 : 1;
}
int main()
{
n=read(),m=read();
int flag_lz=0;
for(int i=1;i<n;++i)
{
int a=read(),b=read(),c=read();
if(a==b+1||b==a+1) flag_lz++;
add_edge(a,b,c);
add_edge(b,a,c);
}
for(int i=1;i<=m;++i)
S[i]=read(),T[i]=read();
if(m==1)
{
dfs_30(S[1],0,T[1]);
printf("%d\n",tot_30-max_30);
return 0;
}
if(n<=1000)
{
int ans=0x3f3f3f3f;
for(int i=1;i<=2*n-2;i+=2) // 枚举航道
{
int tmp=e[i].q;
e[i].q=e[i+1].q=0;
int dsr=0;
for(int j=1;j<=m;++j) //遍历客户
{
flag_30=tot_30=0;
dfs_30(S[j],0,T[j]);
dsr=max(dsr,tot_30);
}
ans=min(ans,dsr);
e[i].q=e[i+1].q=tmp;
}
printf("%d\n",ans);
return 0;
}
if(flag_lz==n-1)
{
for(int i=1,j=2;i<=2*(n-1);i+=2,j++)
a[j]=e[i].q;
for(int i=2;i<=n;++i)
sum[i]=sum[i-1]+a[i];
for(int i=1;i<=m;++i)
{
if(S[i]>T[i]) swap(S[i],T[i]);
num[i]=sum[T[i]]-sum[S[i]];
}
int l=1,r=3e8;
int ans;
while(l<=r)
{
int mid=(l+r)>>1;
if(check(mid)) ans=mid,r=mid-1;
else l=mid+1;
}
printf("%d\n",ans);
return 0;
}
return 0;
}

luogu P2680 运输计划 65分做法的更多相关文章

  1. Luogu P2680 运输计划(二分+树上差分)

    P2680 运输计划 题意 题目背景 公元\(2044\)年,人类进入了宇宙纪元. 题目描述 公元\(2044\)年,人类进入了宇宙纪元. \(L\)国有\(n\)个星球,还有\(n-1\)条双向航道 ...

  2. [luogu]P2680 运输计划[二分答案][树上差分]

    [luogu]P2680 [NOIP2015]运输计划 题目背景 公元 2044 年,人类进入了宇宙纪元. 题目描述 L 国有 n 个星球,还有 n-1 条双向航道,每条航道建立在两个星球之间,这 n ...

  3. luogu P2680 运输计划 (二分答案+树上差分)

    题目背景 公元 20442044 年,人类进入了宇宙纪元. 题目描述 公元20442044 年,人类进入了宇宙纪元. L 国有 nn 个星球,还有 n-1n−1 条双向航道,每条航道建立在两个星球之间 ...

  4. luogu P2680 运输计划

    传送门 要最长链的长度最短,一秒想到二分,因为如果对于某个长度满足改掉一边的边权后能使得所有链长度不超过该长度,则所有比他长的长度也满足. 二分最终答案.我们要使得原来长度大于二分的\(mid\)的链 ...

  5. 洛谷 P2680 运输计划 解题报告

    P2680 运输计划 题目背景 公元2044年,人类进入了宇宙纪元. 题目描述 公元2044年,人类进入了宇宙纪元. \(L\)国有\(n\)个星球,还有\(n-1\)条双向航道,每条航道建立在两个星 ...

  6. 洛谷 P2680 运输计划-二分+树上差分(边权覆盖)

    P2680 运输计划 题目背景 公元 20442044 年,人类进入了宇宙纪元. 题目描述 公元20442044 年,人类进入了宇宙纪元. L 国有 nn 个星球,还有 n-1n−1 条双向航道,每条 ...

  7. P2680 运输计划(二分+树上差分)

    P2680 运输计划 链接 分析: 二分+树上差分. 首先可以二分一个答案,那么所有比这个答案大的路径,都需要减去些东西才可以满足这个答案. 那么减去的这条边一定在所有的路径的交集上. 那么如果求快速 ...

  8. 洛谷——P2680 运输计划

    https://www.luogu.org/problem/show?pid=2680 题目背景 公元 2044 年,人类进入了宇宙纪元. 题目描述 L 国有 n 个星球,还有 n-1 条双向航道,每 ...

  9. P2680 运输计划

    http://www.luogu.org/problem/show?pid=2680#sub 题目背景 公元 2044 年,人类进入了宇宙纪元. 题目描述 L 国有 n 个星球,还有 n-1 条双向航 ...

随机推荐

  1. Qt中容器类应该如何存储对象(对象加入到容器时会发生拷贝,容器析构时,容器内的对象也会析构)

    Qt提供了丰富的容器类型,如:QList.QVector.QMap等等.详细的使用方法可以参考官方文档,网上也有很多示例文章,不过大部分文章的举例都是使用基础类型:如int.QString等.如果我们 ...

  2. MySQL5.6命令笔记

    授权root用户在远程终端访问 ' WITH GRANT OPTION;

  3. 浅析I/O处理过程与存储性能的关系

    浅析I/O处理过程与存储性能的关系 https://community.emc.com/docs/DOC-28653 性能”这个词可以说伴随着整个IT行业的发展,每次新的技术出现,从硬件到软件大多数情 ...

  4. SQLCE数据工具(Flyhoward Ltd SDF Viewer)

    SDF Viewer sdf数据库创建编辑查看 官方下载地址  http://www.flyhoward.com/Download_SDF_Viewer.aspx 用户名:www.cr173.com注 ...

  5. LVS + Keepalived 实现高可用、负载均衡 Web 集群

    简介: LVS 是 Linux Virtual Server 的简写,Linux 虚拟服务器的意思,是一个虚拟的服务器集群系统,此项目由章文嵩博士于 1998 年 5 月成立,是中国最早出现的自由软件 ...

  6. Python中的类属性、实例属性与类方法、静态方法

    1.什么是类对象,实例对象 类对象:类名 实例对象:类创建的对象 2.类属性就是类对象所拥有的属性,它被所有类对象的实例对象所共有,在内存中只存在一个副本,这个和C++.Java中类的静态成员变量有点 ...

  7. ID和Name

    ID和Name都可以用来标识一个标记,Javascript分别有两个方法getElementById和getElementByName来定位Dom节点. 区别如下: 1.我们知道在网页做Post提交时 ...

  8. 浅谈Java中的初始化和清理

    引言 这篇文章我们主要介绍Java初始化和清理的相关内容,这些内容虽然比较基础,但是还是在这边做一个简单的总结,方便以后查阅. 初始化过程 Java尽力保证:所有变量在使用之前都会得到恰当的初始化(对 ...

  9. 浅谈Android View事件分发机制

    引言 前面的文章介绍了View的基础知识和View的滑动,今天我们来介绍View的另一个核心知识,View的事件分发机制. 点击事件的传递规则 所谓的点击事件的分发机制,其实就是对MotionEven ...

  10. tfs代码上传到server并下载到新位置

    1.svn与git代码管理原理基本一致,基于文档管理,能看到文件代码,通过设置文件的只读属性来控制代码. 而tfs是基于sqlserver及lock来管理,看不见代码文件 2.tfs没有自己的用户管理 ...