参考论文:http://wenku.baidu.com/link?url=qTuT3ghZfvaygqB4a15bL8jN-gNt9BV-A_zOv3HvpSEvR3Ujoz4VbsZwjc7gISRVgoz9QNE6ZNLP1D0T3muLxKh_x5hgMfu57TJd4UwB5va
其他应用:noip 2012 开车旅行 题解:http://blog.youkuaiyun.com/pbihao/article/details/52875298
其实也是在黄学长那里看到的qaq
先把输入数据从小到大排序,然后建一个数组记录下原来的序列中的每一个元素对应新的序列中的数的序号,把新的序列记录下左右连边的编号(双向链表),这样的话,我们从n到1处理原数列的每一个元素,min(a[j]-a[i])就一定在i的左边或者右边,每一次处理完以后就删除链表中的这一个元素就可以保证所有的元素(左右)都在这个元素之前出现过了
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<cmath>
#define maxn 40200
using namespace std;
int n,a[maxn],b[maxn];
struct C{
int x,id,ls,rs;
bool operator<(const C& b)const {return x<b.x;}
}c[maxn];
int main(){
scanf("%d",&

这篇博客介绍了如何利用双向链表解决[HNOI2002]营业额统计问题。首先,将输入数据排序,然后创建一个数组记录排序后每个元素的原始序列位置。接着,构建双向链表存储新序列中元素的相邻关系。通过从n到1遍历原数列,每次处理时删除链表中当前元素,确保所有元素的最小差值已经在遍历过程中处理过。
最低0.47元/天 解锁文章
1028

被折叠的 条评论
为什么被折叠?



