【9.14NOIP模拟pj】wtaxi

题目简化

有K辆车,N个人,上车给D元,只有S分钟。上车后无论多少人都要给D元,原地等多少分钟就没了多少元。求最小花费的钱。


我的思路

毫无疑问,此题可以用搜索做,DFS和BFS都行。

程序1

设三个参数,分别为(第l辆车,共花了sum元,还剩下m人)。花的时间在后面加上,否则有点麻烦一点。

两种情况:选或不选

不选 l+1;

选 l+1,已经花的钱+时间*上车人数+上车需要的钱(D),m-上车的人

程序2

我觉得,纯暴搜定然不过,所以加个记忆化。因为记忆化必须要在后面的操作一样时,才可以比较,取最优的。设bz[l,m]表示在第l辆车,剩m人时花的最少钱(sum)

和sum比较即可

程序3.1

我担心第二代程序过不了,再加了一层优化。有时,剩下的人即使将剩下的车全坐满,仍然不够。所以判断m和剩下的座位之和的关系,若m比其还大,则退出,因为即使后面的坐满,仍不能全走。

(未试过)程序3.2

已经满的车无需考虑


所以,此题可用**DFS+记忆化+剪枝**AC之

程序实践3.1

C++

#include <cstdio>
#include <cstring>
#include <cmath>
#include <climits>
using namespace std;
int n,k,d,s;
int t[101],z[101];
int bz[101][101],sm[102];//bz见上,sm[i]表示到i辆车时剩下的车最多能坐的人数(包括i)
int ans=INT_MAX;
int min_a_b(int a,int b)
{
if (a<b) return a;
return b;
}
void go(int l,int sum,int m)
{
if (sum>bz[l][m]) return;
bz[l][m]=sum;//记忆化操作,把大于之前的排除
if (sm[l]<m) return;//剪枝操作,把大于最大座位的人数排除
if (m<=0)
{
if (sum<ans) ans=sum;//替换ans
return;
}
if (l>k) return;//车没了,人还在的情况
go(l+1,sum+min_a_b(z[l],m)*t[l]+d,m-min_a_b(z[l],m));//选
go(l+1,sum,m);//不选
return;
}
int main()
{
freopen("wtaxi.in","r",stdin);
freopen("wtaxi.out","w",stdout);
int i,j;
scanf("%d%d%d%d",&n,&k,&d,&s);
for(i=1;i<=k;i++)
{
scanf("%d%d",&t[i],&z[i]);
}
for(sm[k+1]=0,i=k;i>0;i--)
{
sm[i]=sm[i+1]+z[i];//求剩下车中最大座位
}
memset(bz,127,sizeof(bz));//初始化
go(1,0,n);
if (ans==INT_MAX)
{
printf("impossible\n");
return 0;
}
printf("%d\n",ans);
return 0;
}

Pascal

var
n,k,d,s:longint;
i,j:longint;
t,z:array[0..100]of longint;
bz:array[0..100,0..100]of longint;//bz见上
sm:array[0..101]of longint;//sm[i]表示到i辆车时剩下的车最多能坐的人数(包括i)
ans:longint=maxlongint;
function min(a,b:longint):longint;
begin
if a<b then exit(a);
exit(b);
end;
procedure go(l,sum,m:longint);
begin
if sum>bz[l,m] then exit;
bz[l,m]:=sum;//记忆化操作,把大于之前的排除
if sm[l]<m then exit;//剪枝操作,把大于最大座位的人数排除
if m<=0 then
begin
if sum<ans then ans:=sum;//替换ans
exit;
end;
if l>k then exit;//车没了,人还在的情况
go(l+1,sum+min(z[l],m)*t[l]+d,m-min(z[l],m));//选
go(l+1,sum,m);//不选
end;
begin
assign(input,'wtaxi.in');reset(input);
assign(output,'wtaxi.out');rewrite(output);
readln(n,k,d,s);
for i:=1 to k do readln(t[i],z[i]);
sm[k+1]:=0;
for i:=k downto 1 do sm[i]:=sm[i+1]+z[i];//求剩下车中最大座位
fillchar(bz,sizeof(bz),127);//初始化
go(1,0,n);
if ans=maxlongint then
begin
writeln('impossible');
close(input);
close(output);
halt;
end;
writeln(ans);
close(input);
close(output);
end.

总结

  1. 类似于这样的题可以用搜索做
  2. 记忆化可以加快程序速度,但要保证程序是正确的,只是删掉不必要的运算

    1.不一定要保证前面走过的路一样

    2.要保证后面的路一样,它们要在同一可以比较的点上,才能记忆化,取最优的
  3. 剪枝也可以删掉一些不必要的运算,但它是根据最不利原则,求出的一个范围,把范围外的去掉

【9.14NOIP模拟pj】wtaxi 题解——搜索的更多相关文章

  1. 【9.14NOIP模拟pj】wtaxi 题解

    [9.14NOIP模拟pj]wtaxi 搜索

  2. [CQOI2012]模拟工厂 题解(搜索+贪心)

    [CQOI2012]模拟工厂 题解(搜索+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1327574 链接题目地址:洛谷P3161 BZOJ P26 ...

  3. Python模拟百度自动输入搜索功能

    # 访问百度,模拟自动输入搜索 # 代码中引入selenium版本为:3.4.3 # 通过Chrom浏览器访问发起请求 # Chrom版本:59 ,chromdriver:2.3 # 需要对应版本的C ...

  4. CF912E Prime Gift题解(搜索+二分答案)

    CF912E Prime Gift题解(搜索+二分答案) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1314956 洛谷题目链接 $     $ CF题目 ...

  5. csps模拟87888990部分题解

    题面:https://www.cnblogs.com/Juve/articles/11752338.html https://www.cnblogs.com/Juve/articles/1175241 ...

  6. 一些noip模拟题一句话题解

    Problem A: 序列 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 12  Solved: 9[Submit][Status][Web Boar ...

  7. 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解

    今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...

  8. NOIP模拟赛 华容道 (搜索和最短路)蒟蒻的第一道紫题

    题目描述 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少需要多少时间. 小 B 玩的华容道 ...

  9. CSP-S模拟测试 88 题解

    T1 queue: 考场写出dp柿子后觉得很斜率优化,然后因为理解错了题觉得斜率优化完全不可做,只打了暴力. 实际上他是可以乱序的,所以直接sort,正确性比较显然,贪心可证,然后就是个sb斜率优化d ...

随机推荐

  1. Java 网络编程(1):使用 NetworkInterface 获得本机在局域网内的 IP 地址

    原文地址:https://segmentfault.com/a/1190000007462741 1.问题提出 在使用 Java 开发网络程序时,有时候我们需要知道本机在局域网中的 IP 地址.很常见 ...

  2. Unity NGUI 粒子的排序

    Unity NGUI系统中是没有对粒子进行排序的,如: 怎么解决这个问题呢? 思路是把粒子的渲染层级,相对于UI组件的层级进行一个偏移. 解决后的效果如下: 代码如下: using System.Co ...

  3. day 87 DjangoRestFramework学习一之restful规范、APIview、解析器组件、Postman等

    DjangoRestFramework学习一之restful规范.APIview.解析器组件.Postman等   本节目录 一 预备知识 二 restful规范 三 DRF的APIView和解析器组 ...

  4. nodejs--express安装失败的原因

    1.检查更新所有的npm ,jade,或者ejs. 2.在用jade或ejs也是有区别的,jade适合个人秀,ejs更实用与商务. 3.express在4.+之后的版本都分离了,推荐用3.+的版本稳定 ...

  5. elasticsearch的基本用法(转载)

    本文出自:http://blog.csdn.net/feelig/article/details/8499614 最大的特点:  1. 数据库的 database, 就是  index  2. 数据库 ...

  6. Array类型中的检测数组,转换方法,栈方法,队列方法

    我的新博客==> http://www.suanliutudousi.com/2017/08/24/array%E7%B1%BB%E5%9E%8B%E4%B8%AD%E7%9A%84%E6%A3 ...

  7. canvas前端压缩图片和视频首屏缩略图并上传到服务器

    图片: var img = document.createElement('img') img.src = window.URL.createObjectURL(fileObj.file) // 加载 ...

  8. 《Java语言程序设计》编程练习6.18(检测密码)

    6.18 (检测密码)一些网站对于密码具有一些规则.编写一个方法,检测字符串是否是一个有效密码.     假定密码规则如下:     • 密码必须至少8位字符.     • 密码仅能包含字母和数字. ...

  9. 随笔-ansible-2

    通过Ansible来搭建一套Web服务架构.[以AD-HOC的形式] Inventory文件内容如下: [proxy] 192.168.40.254 [app] 192.168.40.243 [nos ...

  10. 科普帖:深度学习中GPU和显存分析

    知乎的一篇文章: https://zhuanlan.zhihu.com/p/31558973 关于如何使用nvidia-smi查看显存与GPU使用情况,参考如下链接: https://blog.csd ...