#洛谷1052 dp 状态压缩


传送门

(https://www.luogu.org/problem/show?pid=1052#sub)


做完这道题之后,感觉涨了好多见识,以前做的好多状压题目都是将一维压成一个数,一直感觉状压本质就是位运算来保存状态,这道题给了一个全新的思路,通过裁剪无用的状态来有效的减少状态量,从而使空间和时间达到要求

初看题目感觉还是挺简单的,但是1e9的使得线性dp无论空间还是时间都难以接受,考虑如何减少状态量

发现题目中石子的数量只有100个,而且每次跳跃的距离小于10,可见实际上桥上的石子排列应该非常稀疏,尝试从此处优化

不难发现如果两个石子之间的距离大于一定值时,它们的距离就将失去意义,

比如每次跳跃距离在(5,7),而某两个石子的距离为10000,那么将他们的距离调整为5000对结果无任何影响

优化距离之后直接进行dp转移即可,笔者选择了2 * t作为优化距离的分界线

dp[i] = min(dp[i-j], dp[i]) + (flag[i] == 1)

Warning:

  • 对a数组进行修改操作时,不能对原数组进行修改,例如,a[1] = 1, a[2] = 300 , a[3] = 301,如果在原数组上进行修改,会导致a[2] 被修改为一个较小值,而a[3]此时也会符合修改条件,导致错解

  • 初始化时要注意初始化的值,如果初始化值过大可能导致爆int上限

  • 压缩时可能发生冲突,尤其是在s, t相对接近时,可以适当加大mod的值,同时在压缩两个较远点时适当增加压缩后的距离


#include <cstdio>
#include <algorithm>
#include <cstring> int l, m, s, t;
const int maxn = 1000000 + 500;
int dp[maxn];
int a[maxn];
int d[maxn];
int cur[maxn];
int mod; int main () {
freopen("river.in", "r", stdin);
freopen("river.out", "w", stdout);
scanf("%d %d %d %d", &l, &s, &t, &m);
for (int i = 1; i <= m; i++) scanf("%d", &a[i]);
mod = 2 * t;
std :: sort(&a[1], &a[m + 1]);
for (int i = 1; i <= m; i++) {
if (a[i] - a[i-1] <= mod) {
d[i] = a[i] - a[i-1];
} else {
d[i] = (a[i] - a[i-1]) % mod + mod;
}
}
// for (int i = 1; i <= m; i++) printf("%d ", a[i]);
// printf("\n");
int nowSum = 0;
for (int i = 1; i <= m; i++) {
nowSum += d[i];
cur[nowSum] = 1;
}
for (int i = 0; i <= maxn; i++) dp[i] = 1000000000;
if (l - nowSum > mod)
l = nowSum + mod + (l - nowSum) % mod;
dp[0] = 0;
for (int i = 0; i <= l; i++)
for (int j = s; j <= t; j++) {
dp[i+j] = std :: min(dp[i+j], dp[i] + cur[i+j]);
}
int ans = 0x7fffffff;
for (int j = l; j <= l + 2 * t; j++)
ans = std :: min(ans, dp[j]);
printf("%d", ans); return 0;
}

洛谷 1052 dp 状态压缩的更多相关文章

  1. 洛谷1052(路径压缩后简单dp)

    同POJ3744写法都是一样的. 距离太长无意义可以压缩,注意不是随便压的,想一想可以跟%T发生关系. #include <cstdio> #include <cctype> ...

  2. 洛谷 1373 dp 小a和uim之大逃离 良心题解

    洛谷 1373 dp 这题还不算太难,,当初看的时候不是很理解题意,以为他们会选择两条不同的路径,导致整体思路混乱 传送门 其实理解题意和思路之后还是敲了不短的时间,一部分身体原因再加上中午休息不太好 ...

  3. 洛谷 1063 dp 区间dp

    洛谷 1063 dp 区间dp 感觉做完这道提高组T1的题之后,受到了深深的碾压,,最近各种不在状态.. 初看这道题,不难发现它具有区间可并性,即(i, j)的最大值可以由(i, k) 与 (k+1, ...

  4. 洛谷 2409 dp 月赛题目

    洛谷 2409 dp 洛谷十月月赛T1,一道有些interesting的dp题目,当时做的时候想的比较复杂,根本没有往dp的方向去想.. 非官方题解: 1.据说可以使用优先队列来处理,参见Uva119 ...

  5. HDU 4336 Card Collector (期望DP+状态压缩 或者 状态压缩+容斥)

    题意:有N(1<=N<=20)张卡片,每包中含有这些卡片的概率,每包至多一张卡片,可能没有卡片.求需要买多少包才能拿到所以的N张卡片,求次数的期望. 析:期望DP,是很容易看出来的,然后由 ...

  6. HDU 1074 Doing Homework (dp+状态压缩)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1074 题目大意:学生要完成各科作业, 给出各科老师给出交作业的期限和学生完成该科所需时间, 如果逾期一 ...

  7. hdu_4352_XHXJ's LIS(数位DP+状态压缩)

    题目连接:hdu_4352_XHXJ's LIS 题意:这题花大篇篇幅来介绍电子科大的一个传奇学姐,最后几句话才是题意,这题意思就是给你一个LL范围内的区间,问你在这个区间内最长递增子序列长度恰为K的 ...

  8. hdu 4352 数位dp + 状态压缩

    XHXJ's LIS Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  9. 【bzoj1076】[SCOI2008]奖励关 期望dp+状态压缩dp

    题目描述 你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物,每次你都可以选择吃或者不吃(必须在抛出下一个宝物之前做出选择,且现在决定不吃的宝物以后也不能再 ...

随机推荐

  1. C# try-catch-return

    正常执行try后才能执行finally,catch中的语句可能会影响finally的执行 使用 finally 块,可以清理在 Try 中分配的任何资源,而且,即使在 try 块中发生异常,您也可以运 ...

  2. [Linux]第一部分-认识Linux及Linux主机规划与安装

    ctrl + alt + f1~f6 切换六个终端ctrl + alt + f7 图形化界面 startx 开启x-window桌面 ls -al /root 列出root目录 date日期 +%y/ ...

  3. NYOJ 589 糖果

    糖果 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描写叙述 topcoder工作室的PIAOYIi超级爱吃糖果.如今他拥有一大堆不同种类的糖果.他准备一口气把它们吃完.但是 ...

  4. RabbitMQ从入门到精通

    RabbitMQ从入门到精通 学习了:http://blog.csdn.net/column/details/rabbitmq.html RabbitMQ是AMQP(advanced message ...

  5. tomcat内存大小设置

    tomcat内存大小设置 如果安装为windows服务,需要进行内存设置的时候,选择configure...界面, 在Java Tab页面内可以进行内存参数的设置. 学习了:http://elf884 ...

  6. JS冒泡和闭包案例分析

    背景: 今天逛网页发现了百度知道上一个有意思的JS问题,提问者的问题事实上蛮简单的,懂点前端开发技术的应该都能实现.提问者的要求:实现子菜单的弹出,菜单共同拥有三级.每级菜单显示时有500毫秒的延迟. ...

  7. ios Button

    展现效果例如以下: 功能说明: 1加入来图片背景, 2动态展现百度网页, 3动态加入button. 4展现提示框.展现你点击提示框得index  我成功来你也快来试试. 1 详细得项目创建与拖动but ...

  8. Python 下的 return 关键字

    def make_sum(a, b): return ('+', a, b) >> make_sum(1, 2) ('+', 1, 2) 显示地返回一个元组(tuple),当然 retur ...

  9. http server优雅启停原理及验证

    问题背景 在 http应用程序重启时,如果直接 kill -9 使程序退出,然后再启动,会存在的问题: 旧的请求未处理完,如果服务端进程直接退出,会造成客户端连接中断(收到 RST) 新请求打过来,服 ...

  10. React 父组件触发子组件事件

    Parent组件 import React from "react"; import Child from "./component/Child"; class ...