CodeChef Sum of distances(分治)
CodeChef Sum of distances(分治)
题目大意
有一排点,每个点 i 向 \(i + 1, i + 2, i + 3\) 分别连价值为 \(a_i,b_i,c_i\) 的有向边,问两两间最短路之和
数据范围
\(1 \le n \le 10^5\)
解题思路
这种题已经从新颖变成套路了(唉)
考虑分治,很容易发现如果断掉连续的三个点那么图就不再联通,我们从中间找三个点,然后分别向两边跑最短路,设点 i 到三点最短距离为 \(x_1,x_2,x_3\),三点到 j 最短距离为 \(y_1,y_2,y_3\)
那么对答案的贡献为 \(\min(x_1+y_1,x_2+y_2,x_3+y_3)\)
考虑 \(x_1+y_1\) 最小,有
x_1-x_2 \le y_2-y_1,x_1-x_3 \le y_3-y_1
\]
简单的二维偏序问题,但实现起来较为复杂,考虑 \(x_2+y_2\) 时注意小于等于号和小于号的情况
代码先咕了
CodeChef Sum of distances(分治)的更多相关文章
- 834. Sum of Distances in Tree —— weekly contest 84
		
Sum of Distances in Tree An undirected, connected tree with N nodes labelled 0...N-1 and N-1 edges a ...
 - [Swift]LeetCode834. 树中距离之和 | Sum of Distances in Tree
		
An undirected, connected tree with N nodes labelled 0...N-1 and N-1 edges are given. The ith edge co ...
 - 2018.11.17 codechef PRIMEDST(点分治+fft)
		
传送门 fftfftfft一眼题(其实最先想到的是nttnttntt,wawawa了几次之后发现模数不够大果断弃疗写fftfftfft) 我们点分治统计答案的个数. 考虑现在已经统计出了到当前点的所有 ...
 - [LeetCode] 834. Sum of Distances in Tree 树中距离之和
		
An undirected, connected tree with N nodes labelled 0...N-1 and N-1 edges are given. The ith edge co ...
 - [LeetCode] 834. Sum of Distances in Tree
		
LeetCode刷题记录 传送门 Description An undirected, connected treewith N nodes labelled 0...N-1 and N-1 edge ...
 - 【leetcode】834. Sum of Distances in Tree(图算法)
		
There is an undirected connected tree with n nodes labeled from 0 to n - 1 and n - 1 edges. You are ...
 - Codechef SEP14 QRECT cdq分治+线段树
		
题意 支持删除矩阵.插入矩阵.查询当前矩阵与之前有多少个矩阵相交 算相交的时候容斥一下:相交矩形数 = 总矩形数-X轴投影不相交的矩形数-Y轴投影不相交的矩形数-XY轴投影下都不相交的矩形数 最后一项 ...
 - 树中的路径和 Sum of Distances in Tree
		
2019-03-28 15:25:43 问题描述: 问题求解: 写过的最好的Hard题之一. 初看本题,很经典的路径和嘛,dfs一遍肯定可以得到某个节点到其他所有节点的距离和.这种算法的时间复杂度是O ...
 - codechef Sum of Cubes 图论
		
正解:图论+数学 解题报告: 先放个传送门QwQ 然后放下题目大意?就说给定简单图,无自环或重边,然后求(∑e[i][j])k,i,j∈S,S为点集的子集 然后因为k的取值只有[1,3],所以这里分类 ...
 
随机推荐
- drf之框架基础
			
(一)drf基础 全称:django-rest framework 接口:什么是接口.restful接口规范(协议) CBV(基于FBV的基础上形成).CBV生命周期源码----基于restful规范 ...
 - 超详细Maven技术应用指南
			
该文章,GitHub已收录,欢迎老板们前来Star! GitHub地址: https://github.com/Ziphtracks/JavaLearningmanual 搜索关注微信公众号" ...
 - 循序渐进VUE+Element 前端应用开发(12)--- 整合ABP框架的前端登录处理
			
VUE+Element 前端是一个纯粹的前端处理,前面介绍了很多都是Vue+Element开发的基础,从本章随笔开始,就需要进入深水区了,需要结合ABP框架使用(如果不知道,请自行补习一下我的随笔:A ...
 - Java多线程之内存模型
			
目录 多线程需要解决的问题 线程之间的通信 线程之间的通信 Java内存模型 内存间的交互操作 指令屏障 happens-before规则 指令重排序 从源程序到字节指令的重排序 as-if-seri ...
 - 一文读懂:GBDT梯度提升
			
先缕一缕几个关系: GBDT是gradient-boost decision tree GBDT的核心就是gradient boost,我们搞清楚什么是gradient boost就可以了 GBDT是 ...
 - git提交时报错:Updates were rejected because the tip of your current branch is behind
			
有如下3种解决方法: 1.使用强制push的方法:git push -u origin master -f这样会使远程修改丢失,一般是不可取的,尤其是多人协作开发的时候. 2.push前先将远程rep ...
 - 05[掌握]高可用、集群、持久化、docker 等前置知识点
			
高可用 24小时对外提供服务 高并发 同一时间段能处理的请求数 1,中心化和去中心化 1.1,中心化 意思是所有的节点都要有一个主节点 缺点:中心挂了,服务就挂了 中心处理数据的能力有限,不能把节点性 ...
 - layui动态添加的元素click等事件触发不了的解决办法
			
在页面加载完成时候 '.add_project' 元素是可以触发click时间的,当动态添加 '.add_project' 时候,新添加的元素却触发不了click事件,类似下面的写法: $(" ...
 - 《UNIX环境高级编程》(APUE) 笔记第八章 - 进程控制
			
8 - 进程控制 Github 地址 1. 进程标识 每个进程都有一个非负整型表示的 唯一进程 ID .进程 ID 是可复用的(延迟复用算法). ID 为 \(0\) 的进程通常是调度进程,常常被称为 ...
 - python之类与对象(一)
			
1.改变对象的字符串显示,要改变一个实例的字符串表示,可重新定义它的 str () 和 repr () 方法 class Pair: def __init__(self, x, y): self.x ...