推(chuan)销员

分析

这里主要阐述一下我的分析思路。

看起来挺直观的。

最初的想法,我们枚举每一个最远点mxp的位置,然后对之前的a进行排序。

那么以mxp为最远点,选x个的最大疲劳值为:



这样的复杂度为,考试时就这样拿了个60pt。

但是,我们要尝试发现这道题的特性,来进行时间上的优化。

根据极大化思想,我们要尽可能排除不影响答案的。

当一定时,设,没有优,这等价于:







当增大的时候,例如变大到,发现的值一定是递增的,因为一定是多一个数,也一样,而能选择到的也能选择得到。

所以我们得到了决策单调性:对于,,没有优,那么随着的增大,仍然没有优,所以对于的询问的决策点会非严格单调递增。

接下来,很容易想到用单调队列什么的进行维护。

但怎么尝试都觉得不行……

这时候就一定要跳出来啦。

根据决策单调性这个重要的特点,考虑换一种思考的角度。

假如当前这个询问我们决策点为,答案为,现在要求这个询问的决策点和答案。

我们有两种方法:

①在之前选择一个没有选择过的点,

②在之后选择一个决策点,

用两个堆实现即可。

有点意思。

代码

#include <cstdio>
#include <cctype>
#include <queue>
using namespace std;

#define rep(i,a,b) for (int i=(a);i<=(b);i++)

#define x first
#define y second
#define mp make_pair

typedef pair<int,int> PII;

const int N=131072;

int n;
int s[N],a[N];

int cur,vis[N];
priority_queue<PII> qs,qb;
int res;

inline int rd(void)
{
    int x=0,f=1; char c=getchar();
    for (;!isdigit(c);c=getchar()) if (c=='-') f=-1;
    for (;isdigit(c);c=getchar()) x=x*10+c-'0';
    return x*f;
}

int main(void)
{
//  freopen("a.in","r",stdin);
//  freopen("a.out","w",stdout);

    n=rd();
    rep(i,1,n) s[i]=rd();
    rep(i,1,n) a[i]=rd();

    rep(i,1,n)
        qb.push(mp(2*s[i]+a[i],i));

    PII t1,t2; int e1,e2,cs;
    rep(i,1,n)
    {
        while (!qs.empty())
        {
            t1=qs.top();
            if (vis[t1.y])
                qs.pop();
            else break;
        }
        while (!qb.empty())
        {
            t2=qb.top();
            if (t2.y<cur||vis[t2.y])
                qb.pop();
            else break;
        }

        e1=(!qs.empty());
        e2=(!qb.empty());
        if (!e1&&e2)
            cs=2;
        else if (e1&&!e2)
            cs=1;
        else if (e1&&e2)
        {
            t1=qs.top(),t2=qb.top();
            if (t2.x-2*s[cur]>=t1.x)
                cs=2;
            else cs=1;
        }

        if (cs==1)
        {
            t1=qs.top(); qs.pop();
            vis[t1.y]=1;
            res+=t1.x;
        }
        else if (cs==2)
        {
            t2=qb.top(); qb.pop();
            vis[t2.y]=1;
            rep(j,cur+1,t2.y)
                if (!vis[j])
                    qs.push(mp(a[j],j));
            res+=(t2.x-2*s[cur]);
            cur=t2.y;
        }

        printf("%d\n",res);
    }

    return 0;
}

【NOIP2015】推销员的更多相关文章

  1. [NOIP2015]推销员

    [NOIP2015]推销员 试题描述 阿明是一名推销员,他奉命到螺丝街推销他们公司的产品.螺丝街是一条死胡同,出口与入口是同一个,街道的一侧是围墙,另一侧是住户.螺丝街一共有 N 家住户,第 i 家住 ...

  2. 【题解】NOIP2015推销员

    ……普及组的题目都做不出来……(:´д`)ゞ……再这样下去要退役了啊…… 不过不管怎样感觉这题还是蛮好的,也要记录一下下~ 我们注意到数据的范围,n 是 1e5, 又有 1e5组询问,暴力大概是 \( ...

  3. NOIP 2015 推销员

    洛谷 P2672 推销员 洛谷传送门 JDOJ 2994: [NOIP2015]推销员 T4 JDOJ传送门 Description 阿明是一名推销员,他奉命到螺丝街推销他们公司的产品.螺丝街是一条死 ...

  4. $NOIp$普及组做题记录

    \([NOIp2014]\) 螺旋矩阵 \(Sol\) 直接模拟,一次走一整行或者一整列.复杂度\(O(n)\). \(Code\) #include<bits/stdc++.h> #de ...

  5. NOIP2015普及组第四题推销员

    好久没有写博客了,今天再写一篇.还是先看题: 试题描述 阿明是一名推销员,他奉命到螺丝街推销他们公司的产品.螺丝街是一条死胡同,出口与入口是同一个,街道的一侧是围墙,另一侧是住户.螺丝街一共有 N 家 ...

  6. 【NOIP2015普及组】推销员_详解

    题目 题目大意 阿明是一名推销员--螺丝街是一条直线,一端有入口,一共有 \(N(<100,000)\) 家住户,第 \(i\) 家住户到入口的距离为 \(S_i\) 米.由于同一栋房子里可以有 ...

  7. NOIP2015普及组T4推销员(暴力+线段树)

    题目:阿明是一名推销员,他奉命到螺丝街推销他们公司的产品.螺丝街是一条死胡同,出口与入口是同一个,街道的一侧是围墙,另一侧是住户.螺丝街一共有N家住户,第i家住户到入口的距离为Si米.由于同一栋房子里 ...

  8. NOIP2015 T4 推销员 贪心+堆优化

    前几天在学堆,这个数据结构貌似挺简单的,但是我看了很久啊QAQ... 今天算是搞懂了吧...于是想到了这道题...(当初悄悄咪咪看题解记得一点) 点我看题 放洛谷的题... 题意的话,大概就是有n个房 ...

  9. [NOIP2015普及组]推销员

    题目:洛谷P2672.codevs5126.Vijos P1977 题目大意:有个推销员要去推销,要你求他推销1~n户人家分别最多花多少“疲劳值”.具体见题目. 解题思路:如果用$O(n^2)$做的话 ...

  10. 【NOIP2015普及组】 推销员(纪中数据-标准)

    题目 [题目描述] 阿明是一名推销员,他奉命到螺丝街推销他们公司的产品.螺丝街是一条死胡同,出口与入口是同一个,街道的一侧是围墙,另一侧是住户.螺丝街一共有 N 家住户,第 i 家住户到入口的距离为 ...

随机推荐

  1. map reduce filter

    三个函数比较类似,都是应用于序列的内置函数.常见的序列包括list.tuple.str.   1.map函数 map函数会根据提供的函数对指定序列做映射. map函数的定义: map(function ...

  2. flume系列之—flume ng使用demo

    摘自:http://rjhym.blog.163.com/blog/static/28130232201263042013972/

  3. Java 常用排序算法/程序员必须掌握的 8大排序算法

    Java 常用排序算法/程序员必须掌握的 8大排序算法 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配 ...

  4. 取出ip address control的ip字符

    1.给这个空间设置control型变量 m_add; 2.定义4个字节型变量,来获取控件中的4个ip字节 BYTE a,b,c,d: m_add.GetAddress(a,,b,c,d): 3.定义I ...

  5. C#占位符与格式化字符串

    原文地址:http://www.cnblogs.com/fumj/articles/2380290.html 在c#中有两种方式可以输出多个字符 其中的一种: static void Main()   ...

  6. BZOJ 2627 JZPKIL

    题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2627 题意:计算下面式子 思路: A先不管.我们来搞B部分.下面说如何计算B这个最 ...

  7. <转>如何改变讨好型人格 | 你根本不需要讨好任何人

    在我过去二十多年的生命里一直是一个“讨好者”. 我总是活在别人对我的期待中,我总是不停的追逐着别人对我的认可,我总是像个卑微的奴才一样去满足别人的需求. 但就和大多数的“讨好者”一样,我们越是寻求别人 ...

  8. 5.4.1 termios结构,关闭回显功能,一键入字符fgetc立刻返回,不用按下回车键

    Linux提供了一组编程接口,用来控制终端驱动程序的行为.这样我们可以更精细的来控制终端. 例如: 回显:允许控制字符的回显,例如读取密码时. 使用termios结构的密码程序 #include &l ...

  9. SQL疑难杂症【3】链接服务器提示"无法启动分布式事物"

    今天接到用户反馈,应用系统出现异常,无法正常使用,于是用Profiler跟踪了一下语句,发现执行的存储过程中调用了链接服务器,做了一些跨服务器操作数据的动作,刚好就是这个链接服务器出错了,错误截图如下 ...

  10. Object-C : Block的实现方式

    摘自:http://www.cnblogs.com/GarveyCalvin/p/4204167.html> Date : 2015-12-4 前言:我们可以把Block当作一个闭包函数,它可以 ...