P1052 过河 题解
复习dp(迪皮)的时候刷到了一道简单路径压缩的题目(一点不会qwq)
正解:
首先呢,我们看到题目,自然而然的会想到这种思路:
设状态变量dp[i]表示从第一个格子开始经过一些跳跃跳到第i个格子上所踩到的最小石子数目。
那么,根据每一次跳s~t个格子,我们可以得出dp[i]可以从dp[i-t]到dp[i-s]转移过来,要综合考虑的话呢,就要在所有之前的情况中取一个石子数最小的在加上当前位置是否有石子数,就是dp[i]的值。
于是呢,有了整体思路,我们开始敲起了代码。
浏览数组范围时发现了这样一个东西:
awsl
这空间时间都会炸吧。。。
于是乎,我们上述的简单套路就被ban掉了。
开始思考:
我们发现在这种数据下,石子间的间隔变得非常的大。
能不能压缩一下那些多余的路径,但是却对答案没有影响呢?
首先,摘取洛谷题解中一位dalao的做法:
我直接没看,被ex到了。
自己思考:
看了看数据范围:
观察dp式子dp[i]=max(dp[i-t]~dp[i-s])+flag[i];flag[i]表示第i个位置有没有石子。
当一段区间不存在石子时,flag就无用了。
于是说白了,就是个统计最大值的过程一旦统计完dp[i]到dp[i-t]的最大值,其后面flag等于0的情况直接就可以跳过了。
不难想出,统计dp[i]到dp[i-t]这个区间的最大值一共需要lcm(s,t)次。
感性理解。。。
于是我们得出了最短压缩长度90.。?(90=9*10,10,10的情况直接特判就行了)
那么,把多余90的距离都压缩成90一定能保证结果不变。
上代码:
#include<cstdio> #include<cstring> #include<algorithm> #define maxn 214748364 using namespace std; int read() { int ans=0; char ch=getchar(),last=' '; while(ch>'9'||ch<'0')last=ch,ch=getchar(); while(ch>='0'&&ch<='9')ans=(ans<<3)+(ans<<1)+ch-'0',ch=getchar(); return last=='-'?-ans:ans; } int min(int a,int b){return a<b?a:b;} inline bool cmp(int a,int b) {return a<b;} int l,s,t,m,sz[20003],ans,dis[20003],sum,flag[20001],dp[20001]; int main(){ l=read(); s=read(),t=read(),m=read(); if(s==t) { int bol; for(int i=1;i<=m;i++) { bol=read();ans+=((bol%s)==0); } printf("%d\n",ans);return 0; } for(int i=1;i<=m;i++) sz[i]=read(); sort(sz+1,sz+1+m,cmp); for(int i=1;i<=m;i++) dis[i]=min(sz[i]-sz[i-1],90);//dis[i]表示第i个石子到第i-1个石子的距离差 dis[m+1]=min(l-sz[m],100); for(int i=1;i<=m;i++) sum+=dis[i],flag[sum]=1; sum+=dis[m+1]; for(int i=1;i<=sum+9;i++) { dp[i]=maxn; for(int j=s;j<=t;j++) { if(i>=j)dp[i]=min(dp[i],dp[i-j]+flag[i]); } } int minn=maxn; for(int i=sum;i<=sum+9;i++) { minn=min(minn,dp[i]); } printf("%d",minn); return 0; }
完结/
也就是说,对于s=t=10的极端情况,只要看100的倍数上有没有石子统计一下就行了。
对于次大的情况s=9,t=10,时,只要把s
原文地址:https://www.cnblogs.com/lbssxz/p/11512697.html
- python mongodb爬取58网站
- 洛谷P1143 进制转换
- python爬取链家租房之获取北京所有区的网站分栏地址(第一次写,code太粗犷,欢迎提建议)
- Pandas-Series知识点总结
- Numpy基础知识点汇总
- P3388 【模板】割点(割顶)
- python爬取链家租房之获取房屋的链接和页面的详细信息
- 信用卡“坏账”客户分析(一)
- 一道简单的sql语句题
- python爬虫反爬取---设置User Agent自动变换header文件
- 一文读懂Python多线程
- 深入理解Python变量作用域与函数闭包
- TensorFlow从1到2 - 5 - 非专家莫入!TensorFlow实现CNN
- JetBrains Rider 破解 (ideaIU等等开发工具都通用)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 恕我直言你可能真的不会java第12篇-如何使用Stream API对Map元素排序
- JavaScript错误处理完全指南
- 从头创建您自己的vue.js——第4部分(构建反应性)
- Oracle 数据库-服务器端字符集查看方法
- Pywinauto 应用后端类型选择错误:AttributeError: 'NoneType' object has no attribute 'backend'. 原因及解决办法
- 恕我直言你可能真的不会java第11篇-Stream API终端操作
- Python+selenium 自动化-滚动的使用方法,如何滚动到元素的位置
- 恕我直言你可能真的不会java第10篇-集合元素归约
- Python+selenium 自动化-模拟键盘输入、点击操作,如何查看所支持的全部键位名称
- Uber为什么放弃Postgres选择迁移到MySQL?
- BAT 批处理命令 - 文件批量复制、克隆功能实例演示
- 【35期】谈谈你对Java线程之间通信方式的理解
- mac 技术篇-修改hosts文件,hosts文件位置
- 一行能装逼的 JavaScript 代码
- python 技术篇-时间戳的获取,记录程序处理时间