PAT L3-017. 森森快递
L3-017. 森森快递
森森开了一家快递公司,叫森森快递。因为公司刚刚开张,所以业务路线很简单,可以认为是一条直线上的N个城市,这些城市从左到右依次从0到(N-1)编号。由于道路限制,第i号城市(i=0, ..., N-2)与第(i+1)号城市中间往返的运输货物重量在同一时刻不能超过 Ci公斤。
公司开张后很快接到了Q张订单,其中第j张订单描述了某些指定的货物要从Sj号城市运输到Tj号城市。这里我们简单地假设所有货物都有无限货源,森森会不定时地挑选其中一部分货物进行运输。安全起见,这些货物不会在中途卸货。
为了让公司整体效益更佳,森森想知道如何安排订单的运输,能使得运输的货物重量最大且符合道路的限制?要注意的是,发货时间有可能是任何时刻,所以我们安排订单的时候,必须保证共用同一条道路的所有货车的总重量不超载。例如我们安排1号城市到4号城市以及2号城市到4号城市两张订单的运输,则这两张订单的运输同时受2-3以及3-4两条道路的限制,因为两张订单的货物可能会同时在这些道路上运输。
输入格式:
输入在第一行给出两个正整数N和Q(2 <= N <= 105, 1 <= Q <= 105),表示总共的城市数以及订单数量。
第二行给出(N-1)个数,顺次表示相邻两城市间的道路允许的最大运货重量Ci(i=0, ..., N-2)。题目保证每个Ci是不超过231的非负整数。
接下来Q行,每行给出一张订单的起始及终止运输城市编号。题目保证所有编号合法,并且不存在起点和终点重合的情况。
输出格式:
在一行中输出可运输货物的最大重量。
输入样例:
10 6
0 7 8 5 2 3 1 9 10
0 9
1 8
2 7
6 3
4 5
4 2
输出样例:
7
样例提示:我们选择执行最后两张订单,即把5公斤货从城市4运到城市2,并且把2公斤货从城市4运到城市5,就可以得到最大运输量7公斤。
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<map>
#include<set>
#define maxn 10010
using namespace std;
typedef long long ll;
int edge[maxn][maxn];
vector<int> E[maxn];
ll ans = ;
int vis[maxn] = {};
void dfs( int x, ll sum ) {
if( sum > ans ) {
ans = sum;
}
for( int i = ; i < E[x].size(); i ++ ) {
if( !vis[E[x][i]] ) {
vis[E[x][i]] = ;
dfs( E[x][i], sum + edge[x][E[x][i]] );
vis[E[x][i]] = ;
}
}
}
int main() {
int n, m, a[maxn], t = 1e9;
cin >> n >> m;
for( int i = ; i < n - ; i ++ ) {
cin >> a[i];
/* edge[i].push_back( make_pair( i + 1, a[i] ) );
edge[i+1].push_back( make_pair( i, a[i] ) );*/
edge[i][i+] = a[i];
edge[i+][i] = a[i];
for( int j = ; j < i - ; j ++ ) {
t = 1e9;
for( int k = j; k < i; k ++ ) {
t = min( t, a[k] );
}
/*edge[j].push_back( make_pair( i, t ) );
edge[i].push_back( make_pair( j, t ) );*/
edge[i][j] = t;
edge[j][i] = t;
}
}
while( m -- ) {
int x, y;
cin >> x >> y;
E[x].push_back(y);
E[y].push_back(x);
}
for( int i = ; i <= n - ; i ++ ) {
/*for( int j = 0; j < E[i].size(); j ++ ) {
cout << E[i][j] << " " << edge[i][E[i][j]] << "--";
}
cout << endl;*/
memset( vis, , sizeof(vis) );
vis[i] = ;
dfs( i, );
}
cout << ans - << endl;
return ;
}
比赛后看大佬用线段树+贪心做的
https://blog.csdn.net/hnust_derker/article/details/79552988
/**
因为一个区间[l, r]的最大货运量就是min([l, r]), 对于两个区间[l, r], [L, R] 假设(r <= R)
1. 两个区间完全不相交, 则最大货运量就是min([l, r]) + min([L, R]),谁先取谁后取都是一样 2.[l, r]完全包含于[L, R],那么肯定选择[l, r]且取其最大货运量,因为min[l, r] >= min[L, R],如果选择两个订单的话,最大货运量都
是min[l, r], 但是单独取[l, r]这个区间, 那么对周围影响的区间都小, 往左往右才可能有更优的取值, 如果[L, R]这个区间要取的话,
这里的每个值都要减去一个值,且最终[l, r]的结果是一样的, 所以肯定取[l,r]且保证货运量最大 3.两区间相交,如果若干个区间已经按右端点从小到大排好序,相同按左端点排序,假设相交于[L, r], 那么两个区间的最大值就是
min{min[L, r], min[l, r] + min[L, R]}这个值是不变的,但是如果[L, R]取得大的话, 对后面的可能相交区间最小值影响就大, 所以要对
l, r取尽可能大, L, R取尽可能小 所以就是: 区间已经按右端点从小到大排好序,相同按左端点排序, 然后从左往右,遇到一个区间就取其区间最小值加到ans上去, 然后更新这个区间
*/ #include<bits/stdc++.h>
typedef long long ll;
const ll maxn = 2e5 + ;
const ll INF = 1e10;
using namespace std; typedef pair<ll, ll> pa;
ll n, m, T, kase = ;
ll C[maxn * ], lazy[maxn * ], d[maxn];
pa lst[maxn]; void push_down(ll o) {
ll o1 = o << , o2 = o << | ;
if(!lazy[o]) return ;
lazy[o1] += lazy[o]; lazy[o2] += lazy[o];
C[o1] -= lazy[o]; C[o2] -= lazy[o]; lazy[o] = ;
} void build(ll o, ll l, ll r) {
lazy[o] = ;
if(l == r) { C[o] = d[l]; return ; }
ll mid = (l + r) >> ;
build(o << , l, mid);
build(o << | , mid + , r);
C[o] = min(C[o << ], C[o << | ]);
} ll ql, qr, data;
ll query_min(ll o, ll l, ll r) {
if(l >= ql && r <= qr) return C[o];
if(l > qr || r < ql) return INF;
ll mid = (l + r) >> ;
push_down(o);
ll p1 = query_min(o << , l, mid);
ll p2 = query_min(o << | , mid + , r);
C[o] = min(C[o << ], C[o << | ]);
return min(p1, p2);
} void update(ll o, ll l, ll r) {
if(l >= ql && r <= qr) {
C[o] -= data; lazy[o] += data;
return ;
}
if(l > qr || r < ql) return ;
push_down(o);
ll mid = (l + r) >> ;
update(o << , l, mid);
update(o << | , mid + , r);
C[o] = min(C[o << ], C[o << | ]);
} int main() {
while(scanf("%lld %lld", &n, &m) != EOF) {
for(ll i = ; i < n - ; i++) scanf("%lld", &d[i]);
build(, , n - );
for(ll i = ; i < m; i++) {
scanf("%lld %lld", &ql, &qr);
if(ql > qr) swap(ql, qr); qr--;
lst[i] = pa(qr, ql);
}
ll ans = ; sort(lst, lst + m);
for(int i = ; i < m; i++) {
ql = lst[i].second; qr = lst[i].first;
ll mt = query_min(, , n - );
ans += mt; data = mt; update(, , n - );
}
printf("%lld\n", ans);
}
return ;
}
PAT L3-017. 森森快递的更多相关文章
- L3-2 森森快递 (30 分)(贪心+线段树/分块)
题目链接:https://pintia.cn/problem-sets/1108203702759940096/problems/1108204121661857798 题目大意: 森森开了一家快递公 ...
- L3-017 森森快递 (30 分)
森森开了一家快递公司,叫森森快递.因为公司刚刚开张,所以业务路线很简单,可以认为是一条直线上的N个城市,这些城市从左到右依次从0到(编号.由于道路限制,第i号城市(,)与第(号城市中间往返的运输货物重 ...
- PAT-GPLT L3-017 森森快递(贪心 + 线段树)
链接: https://www.patest.cn/contests/gplt/L3-017 题意: 给出直线上的N个顶点,(N-1)条边的限制值(每对相邻的顶点之间都有一条边),以及Q个区间(给出起 ...
- PAT天梯赛练习题 L3-010. 是否完全二叉搜索树(完全二叉树的判断)
L3-010. 是否完全二叉搜索树 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 将一系列给定数字顺序插入一个初始为空的二叉搜 ...
- PTA刷题笔记
PTA刷题记录 仓库地址: https://github.com/Haorical/Code/tree/master/PTA/GPLT 两周之内刷完GPLT L2和L3的题,持续更新,包括AK代码,坑 ...
- 周末惊魂:因struts2 016 017 019漏洞被入侵,修复。
入侵(暴风雨前的宁静) 下午阳光甚好,想趁着安静的周末静下心来写写代码.刚过一个小时,3点左右,客服MM找我,告知客户都在说平台登录不了(我们有专门的客户qq群).看了下数据库连接数,正常.登录阿里云 ...
- 快递Api接口 & 微信公众号开发流程
之前的文章,已经分析过快递Api接口可能被使用的需求及场景:今天呢,简单给大家介绍一下微信公众号中怎么来使用快递Api接口,来完成我们的需求和业务场景. 开发语言:Nodejs,其中用到了Neo4j图 ...
- 《转载》PAT 习题
博客出处:http://blog.csdn.net/zhoufenqin/article/details/50497791 题目出处:https://www.patest.cn/contests/pa ...
- 识别快递单号(2) - 加载图片到canvas
传送门: 识别快递单号(1) - 图像处理 转载请注明出处: http://www.cnblogs.com/zaiyuzhong/p/load-image-to-canvas.html 上篇说到我 ...
随机推荐
- 我与微笑哥以及 Java 极客技术的前世今生
关注公众号,大家可以在公众号后台回复“博客园”,免费获得作者 Java 知识体系/面试必看资料. Hello,大家好,我是子悠,Java 极客技术团队的作者之一,本周是六月的第三周,将由我给大家编辑 ...
- Kubernetes容器集群管理环境 - 完整部署(中篇)
接着Kubernetes容器集群管理环境 - 完整部署(上篇)继续往下部署: 八.部署master节点master节点的kube-apiserver.kube-scheduler 和 kube-con ...
- MySQL操作命令梳理(2)
一.表操作 在mysql运维操作中会经常使用到alter这个修改表的命令,alter tables允许修改一个现有表的结构,比如增加或删除列.创造或消去索引.改变现有列的类型.或重新命名列或表本身,也 ...
- 自定义 Button 选择器
极力推荐文章:欢迎收藏 Android 干货分享 阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android 本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以 ...
- Jquery.form异步上传文件常见问题解决
Jquery.form常用方法我就不多说,主要说一下在使用过程中碰到的问题 1.提示 “xxxx” is not define 或者"xxx" is not a function ...
- MySQL多表(理论知识总结)
1. 多表关系 外键 foreign key 添加外键语法: alter table 表名1 add foreign key(外键名称) references 表名2(主键名称 ...
- golang 结合实例更好的理解参数传递和指针
关于参数传递 其实go的参数传递,核心就是一句话:go里所有参数传递都是值传递,既把参数复制一份放到函数里去用. go的函数传参,不管参数是什么类型,都会复制一份,然后新的参数在函数内部被使用. 不像 ...
- Docker 前沿概述
目录 Docker 前沿概述 什么是Docker? Docker的基本概念 容器(Container) -- 镜像运行时的实体 镜像(Image) -- 一个特殊的文件系统 仓库(Repository ...
- .netcore持续集成测试篇之 .net core 2.1项目集成测试
系列目录 从.net到.net core以后,微软非常努力,以每年一到两个大版本的频率在演进.net core,去年相继发布了.net core 2.1和2.2,其中2.1是长期支持版,不断的快速更新 ...
- Sublime Text 3 使用手册
Ctrl+Shift+P:打开命令面板 Ctrl+P:搜索项目中的文件 Ctrl+G:跳转到第几行 Ctrl+W:关闭当前打开文件 Ctrl+Shift+W:关闭所有打开文件 Ctrl+Shift+V ...