P2672 推销员

下面讲正确的贪心

题解

考虑当推销员要推销 i 家客户时,他可以有两种选择:

(1)选择前 i 家疲劳值 a 最大的客户,加上这些客户里最远的距离

(2)选择前 i-1 家疲劳值 a 最大的客户,然后从后边找一个距离最远的客户

所以贪心思路就出来了

考虑维护什么?

反正怎样都是与疲劳值息息相关,那不如先按照疲劳值从大到小sort一下好了

then

sum[ i ]  前 i 个疲劳值最大的客户,疲劳值之和

x[ i ]  前 i 个疲劳值最大的客户中(也就是sum[ i ]中),距离起点最远的那个客户的距离

hou[ i ]  (sort之后)后 i 个客户中单独推销最大的那个客户的 单推值(=距离*2+疲劳值)

对于每一个 i ,ans就是:

max(sum[ i-1 ]+hou[ i ] , sum[ i ]+q[ i ])

代码

#include<bits/stdc++.h>

using namespace std;

const int maxn=1e5+;
int n;
int sum[maxn],hou[maxn],x[maxn]; struct node
{
int s,a;
}peo[maxn]; bool cmp(node x,node y)
{
return x.a >y.a ;
} int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d",&peo[i].s );
for(int i=;i<=n;i++)
scanf("%d",&peo[i].a );
sort(peo+,peo+n+,cmp);
for(int i=;i<=n;i++)
{
sum[i]=sum[i-]+peo[i].a ;
x[i]=max(x[i-],peo[i].s* );
}
for(int i=n;i>=;i--)
hou[i]=max(hou[i+],peo[i].s*+peo[i].a ); for(int i=;i<=n;i++)
{
printf("%d\n",max(sum[i-]+hou[i],sum[i]+x[i]));
} return ;
}

后记

带坏萌新

这题数据好水啊,一个错误的贪心井然可以AC

一个nice数据可以卡死这个错误代码

有Bug:测试数据为:5 1 2 4 2 5 5 4 4 3 2

正确输出:12 17 21 25 28

下面这个程序的输出:12 17 21 24 28

代码

#include<bits/stdc++.h>

using namespace std;

const int maxn=1e5+10;
int n,k,rode; long long ans=0; struct node
{
int s,a,dt;
}peo[maxn]; bool cmp(node x,node y)
{
return x.a >y.a ;
} int main()
{
scanf("%d\n",&n);
if(n==1)
{
int x,y;
scanf("%d\n",x*2+y);
return 0;
}
for(int i=1;i<=n;i++)
scanf("%d",&peo[i].s );
for(int i=1;i<=n;i++)
{
scanf("%d",&peo[i].a );
peo[i].dt =peo[i].s *2+peo[i].a ;
if(peo[i].dt>ans)
{
ans=peo[i].dt ;
k=i;
}
}
printf("%ld\n",ans);
rode=peo[k].s;
peo[k].a =-1;
sort(peo+1,peo+n+1,cmp); for(int i=1;i<n;i++)
{
if(peo[i].s <=rode )
{
ans+=peo[i].a ;
printf("%ld\n",ans);
}
else
{
ans+=peo[i].a ;
ans-=rode*2;
ans+=peo[i].s *2;
rode=peo[i].s ;
printf("%ld\n",ans);
}
} return 0;
}

P2672 推销员(已经补锅)的更多相关文章

  1. 洛谷 P2672 推销员 解题报告

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

  2. P1364 医院设置 (补锅,memset初始化较大值不可用0x7fffffff )

    P1364 医院设置 题解 弗洛伊德水过 注意初始化一个大数 0x3f 可以,0x5f 好像也可以,但是0x7fffffff 我是真的炸了,初始化为-1 (后面补锅有详细解释) 代码 #include ...

  3. luogu P2672 推销员 |贪心

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

  4. 洛谷P2672 推销员 题解 贪心

    题目链接:https://www.luogu.org/problem/P2672 这道题目是贪心,贪心的思想是: 选择 \(m\) 户人家的最大疲劳值应该是以下两种方案中的较大值: 方案一:选择 \( ...

  5. [火星补锅] 水题大战Vol.2 T2 && luogu P3623 [APIO2008]免费道路 题解

    前言: 如果我自己写的话,或许能想出来正解,但是多半会因为整不出正确性而弃掉. 解析: 这题算是对Kruskal的熟练运用吧. 要求一颗生成树.也就是说,最后的边数是确定的. 首先我们容易想到一个策略 ...

  6. P2672 推销员

    贪心,水题 #include <bits/stdc++.h> using namespace std; const int maxn = 1000000; struct house { i ...

  7. 洛谷P2672 推销员

    沙雕贪心...... 我一开始想的是倒着来,每次减去一个. 然后我们就有两个决策:去掉最后一个/去掉前面某一个. 然后第一个决策用并查集维护,第二个决策用线段树即可.仔细想想觉得普及组不会考这种东西, ...

  8. P2672 推销员 优先队列 + 贪心

    ---题面--- 题解: 我会说我想这道普及组题都想了好久么.... 不熟练的普及组选手.jpg 最后随便猜了一个结论居然是对的... 放结论: 假设x = i的最优决策为f[i], 那么f[i + ...

  9. 洛谷 P2672 推销员

    题目传送门 解题思路: 我们会发现本题有一个特性,就是如果我们走到一个更远的地方,那么近的地方距离原点的距离我们可以忽略. 本题要求最大的疲劳值,所以我们需要排序,第一个想到堆,反正我是先想到堆. 然 ...

随机推荐

  1. windows环境变量和相关命令操作

    1.很多程序在windows上运行都需要设置环境变量. 2.具体步骤 复制路径 打开系统设置 高级系统设置 环境变量 设置path 重启cmd 3.可以把路径设置成变量,这样就不用随时 改path而是 ...

  2. js中 base64 转二进制

    function base64toBlob(base64,type) { // 将base64转为Unicode规则编码 let bstr = atob(base64, type), n = bstr ...

  3. linux图形界面安装

    1.问题现象 1.1 startx命令不可用 [root@linuxtest2 ~]# startx 1.3 init 5无法执行完成 [root@linuxtest2 ~]#init 5 2.问题原 ...

  4. centos 7 搭建 LNMP ( Linux+Nginx+MySQL+PHP )

    操作系统 | CentOS Linux release 7.6.1810 (Core) [root@localhost ~# cat /etc/redhat-release CentOS Linux ...

  5. DockerScan:Docker安全分析&测试工具

    DockerScan:Docker安全分析&测试工具 今天给大家介绍的是一款名叫DockerScan的工具,我们可以用它来对Docker进行安全分析或者安全测试. 项目主页 http://gi ...

  6. .htaccess防盗链方法(文件、图片)

    http标准协议中有专门的字段记录referer,一来可以追溯上一个入站地址是什么,二来对于资源文件,可以跟踪到包含显示他的网页地址是什么. 因此所有防盗链方法都是基于这个Referer字段两种方法: ...

  7. JavaScript中数组元素删除的七大方法汇总

    原文链接:https://blog.csdn.net/u010323023/article/details/52700770 在JavaScript中,除了Object之外,Array类型恐怕就是最常 ...

  8. RDO远程连接时错误提示解决办法

    RDO远程连接时提示“远程计算机需要网络级别身份验证,而您的计算机不支持该验证,请联系您的系统管理员或者技术人员来获得帮助” 1.先用个人电脑自带远程工具mstsc连接到服务器Windows Serv ...

  9. HihoCoder1087Hamiltonian Cycle(DP状态压缩)

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 Given a directed graph containing n vertice (numbered from 1 ...

  10. qt5--鼠标操作

    #include "mylabel.h" #include <QDebug> #include <QPointF> #include <QPoint& ...