当前位置: 首页 > news >正文

XMOJ3065 旅游线路

10分钟没啥思路就去看题解了,结果发现很蠢。

题目大意

有一条河,河的东侧和西侧分别有 n , m n,m n,m 个景点,每个景点有个权值。有 k k k 条船,每条船连接东侧和西侧的一个景点。定义一个旅游线路是通过船连接起来的景点序列。一个旅游线路合法当且仅当线路中任意两条船不相交,即不存在两条船 ( x 1 , y 1 ) (x_1,y_1) (x1,y1) ( x 2 , y 2 ) (x_2,y_2) (x2,y2)使得 x 1 > x 2 x_1>x_2 x1x2 并且 y 1 < y 2 y_1<y_2 y1y2 ,或者 x 1 = x 2 , y 1 = y 2 x_1=x_2,y_1=y_2 x1=x2,y1=y2。一个旅游线路的权值定义为线路中所有景点权值之和,求美丽值最大的合法旅游线路。

n , m ≤ 40000 n,m≤40000 n,m40000 k ≤ 1 0 5 k≤10^5 k105

题解

发现一条合法线路当且仅当下一个东侧点大于上一个东侧点,下一个西侧点大于上一个西侧点,也就是“z”形走位。

于是将每条边排序,东侧点为第一关键字,西侧点为第二关键字,这样可以保证每次选的边都和前面不相交。因为对于走到某个东侧点时,西侧点比他小的总是先被选完,而对于一个西侧点也同理。

然后就可以直接dp了。

感觉这个排序很神奇,明明思路很直接但就是一下子没想到。太聪明了。

Code

#include<bits/stdc++.h>
using namespace std;const int N=40000+5,M=1e5+5,INF=1e9;int n,m,k,ans,a[N],b[N],f[N][2];struct giao{int a,b;
}c[M];bool cmp(giao x,giao y){return x.a!=y.a?x.a<y.a:x.b<y.b; 
}int main(){freopen("route.in","r",stdin);freopen("route.out","w",stdout);scanf("%d%d%d",&n,&m,&k);for(int i=1;i<=n;i++){scanf("%d",&a[i]);f[i][0]=a[i];ans=max(ans,a[i]);}for(int i=1;i<=m;i++){scanf("%d",&b[i]);f[i][1]=b[i];ans=max(ans,b[i]);}for(int i=1;i<=k;i++)scanf("%d%d",&c[i].a,&c[i].b);sort(c+1,c+1+k,cmp);for(int i=1;i<=k;i++){int sa=f[c[i].b][1]+a[c[i].a],sb=f[c[i].a][0]+b[c[i].b];f[c[i].a][0]=max(f[c[i].a][0],sa);f[c[i].b][1]=max(f[c[i].b][1],sb);ans=max(ans,max(f[c[i].a][0],f[c[i].b][1]));}printf("%d",ans);return 0;
}
http://www.lryc.cn/news/459282.html

相关文章:

  • 量化之一:均值回归策略
  • NVIDIA Bluefield DPU上的启动流程4个阶段分别是什么?作用是什么?
  • 最优美公式-欧拉公式,轻松理解版
  • 【力扣 | SQL题 | 每日3题】力扣1107,1112, 1077
  • 计算机网络(十一) —— 数据链路层
  • 使用PyTorch从0实现Fashion-MNIST数据集分类
  • Java数组的值拷贝和地址拷贝
  • 类与对象 中(剩余部分) 以及 日历
  • iOS 14 自定义画中画悬浮窗 Custom AVPictureInPictureController 实现方案
  • 【C#生态园】完整解读C#网络通信库:从基础到实战应用
  • js面试题---事件委托是什么
  • 谷歌浏览器 文件下载提示网络错误
  • 【记录】PPT|PPT 箭头相交怎么跨过
  • Linux中如何修改root密码
  • 中间件:SpringBoot集成Redis
  • 数据中心建设方案,大数据平台建设,大数据信息安全管理(各类资料原件)
  • TDD(测试驱动开发)是否已死?
  • Debezium系列之:实时从TDengine数据库采集数据到Kafka Topic
  • 数据结构(一)顺序表
  • 如何在 Jupyter Notebook 执行和学习 SQL 语句(中)
  • AutosarMCAL开发——基于EB Wdg驱动
  • Linux(1. 基本操作_命令)
  • 难点:Linux 死机定位(进程虚拟地址空间耗尽)
  • 小米路由器刷机istoreOS,愉快上网
  • 微信小程序 - 01 - 一些补充和注意点(补充ing...)
  • 微服务实战——登录(普通登录、社交登录、SSO单点登录)
  • windows 安装 ElasticSearch
  • Oracle Linux 9 (CentOS Stream 9) 安装 node.js 20
  • 【Axure安装包与汉化包附带授权证书】
  • SSH隧道验证的原理及实现例子