【bzoj 1588】 [HNOI2002]营业额统计 双向链表

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

参考论文: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",&
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值