题目



思路

很明显的dp就是不会跑啊,所以最后dfs救了一下场,不出所料,最后果然T了,现在说一下正解。

  • 为什么说是奇怪dp呢,这道题的dp数组是布尔型的,f[i][j][k]代表在到第i行第j列之前是否能组成k,1(能)或者0(不能);
  • 这道题还有一个恶心的地方,就是原始数的存放,可以分n以及n前和n后两个部分来存
  • 为了f数组的第三维不为负数(RE欢迎你),我们进行以下操作
  • 将存入的数都换为正数,因为对于每一位都有加减两种操作
  • 对于每一行,维护一个最大值Max,求\(tot=\sum_{i=1}^{2*n-1} Max_i\),然后在第三维的基础值为tot(统一上移tot位)
  • 然后就是dp了
for(int i=2*n-1;i>n;i--){
for(int j=1;j<=2*n-i;j++){
for(int k=0;k<=2*tot;k++){
if(dp[i][j][k]){
now=k+a[i][j];
if(judge(now))dp[i-1][j][now]=dp[i-1][j+1][now]=1;
now=k-a[i][j];
if(judge(now))dp[i-1][j][now]=dp[i-1][j+1][now]=1;
}
}
}
}
for(int i=n;i>=1;i--){
for(int j=1;j<=i;j++){
for(int k=0;k<=2*tot;k++){
if(dp[i][j][k]){
now=k+a[i][j];
dp[i-1][j][now]=dp[i-1][j-1][now]=1;
now=k-a[i][j];
dp[i-1][j][now]=dp[i-1][j-1][now]=1;
}
}
}
}

分两部分,注意f存的是i行j列>>前<<能否组成k的情况!!如果可以,则就对当前状态进行转移,加或者减

代码

#include<bits/stdc++.h>
using namespace std;
int a[100][60];
int dp[100][60][6005];
int n,tot,Max;
bool judge(int x){
if(x<0 || x>2*tot)return 0;
return 1;
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
int Max=0;
for(int j=1;j<=i;j++){
scanf("%d",&a[i][j]);
a[i][j]=abs(a[i][j]);
Max=max(a[i][j],Max);
}
tot+=Max;
}
for(int i=1;i<n;i++){
int Max=0;
for(int j=1;j<=n-i;j++){
scanf("%d",&a[n+i][j]);
a[n+i][j]=abs(a[n+i][j]);
Max=max(a[n+i][j],Max);
}
tot+=Max;
}
dp[2*n-1][1][tot]=1;
int now=0;
for(int i=2*n-1;i>n;i--){
for(int j=1;j<=2*n-i;j++){
for(int k=0;k<=2*tot;k++){
if(dp[i][j][k]){
now=k+a[i][j];
if(judge(now))dp[i-1][j][now]=dp[i-1][j+1][now]=1;
now=k-a[i][j];
if(judge(now))dp[i-1][j][now]=dp[i-1][j+1][now]=1;
}
}
}
}
for(int i=n;i>=1;i--){
for(int j=1;j<=i;j++){
for(int k=0;k<=2*tot;k++){
if(dp[i][j][k]){
now=k+a[i][j];
dp[i-1][j][now]=dp[i-1][j-1][now]=1;
now=k-a[i][j];
dp[i-1][j][now]=dp[i-1][j-1][now]=1;
}
}
}
}
int ans=0x7f7f7f7f;
for(int i=0;i<=2*tot;i++){
if(dp[0][0][i]){
ans=min(ans,abs(i-tot));
}
if(dp[0][1][i]){
ans=min(ans,abs(i-tot));
}
}
printf("%d\n",ans);
}

奇怪DP之步步为零的更多相关文章

  1. 集训DP复习整理

    DP复习 集训%你赛2:测绘(审题DP) 经过2000+个小时的努力终于把这道题做出来的蒟蒻通 分析: 这道题我一直没做出来的原因就是因为我太蒟了题面看不懂,题面读懂了,其实不是特别难. 题目翻译: ...

  2. GDOI2018 爆零记,Challenge Impossibility

    蒟蒻的GDOI又双叒叕考挂啦...... Day 0 && Day -1 学校月考,貌似考的还不错? 然而考完试再坐船去中山实在是慢啊......晚上10点才到酒店 wifi差评... ...

  3. 方阵里面的dp

    打了一场luogu的信心赛,惊讶地发现我不会T2,感觉像这样在矩阵里面的dp看起来很套路的样子,但是仔细想想还是有很多需要注意的细节. 又想到之前貌似也考过一些类似的题目 然而我并没有改 ,于是打算补 ...

  4. HDU-1114(背包DP)

    Piggy-Bank Problem Description Before ACM can do anything, a budget must be prepared and the necessa ...

  5. hdu1114Piggy-Bank(DP完全背包)

    题意:在ACM可以做任何事情,必须准备和预算获得必要的财政支持.这次行动的主要收入来自不可逆绑定金钱(IBM).背后的想法很简单.每当一些ACM成员有任何小的钱,他把所有的硬币和成小猪银行抛出.你知道 ...

  6. BZOJ3864: Hero meet devil【dp of dp】

    Description There is an old country and the king fell in love with a devil. The devil always asks th ...

  7. DP专题·三(01背包+完全背包)

    1.hdu 2126 Buy the souvenirs 题意:给出若干个纪念品的价格,求在能购买的纪念品的数目最大的情况下的购买方案. 思路:01背包+记录方案. #include<iostr ...

  8. B. Once Again... 解析(思維、DP、LIS、矩陣冪)

    Codeforce 582 B. Once Again... 解析(思維.DP.LIS.矩陣冪) 今天我們來看看CF582B 題目連結 題目 給你一個長度為\(n\)的數列\(a\),求\(a\)循環 ...

  9. P4644 [Usaco2005 Dec]Cleaning Shifts 清理牛棚

    P4644 [Usaco2005 Dec]Cleaning Shifts 清理牛棚 你有一段区间需要被覆盖(长度 <= 86,399) 现有 \(n \leq 10000\) 段小线段, 每段可 ...

随机推荐

  1. 06.Django-用户认证

    用户认证 Django 内置一个 auth 模块,帮助用户实现注册.登录.注销以及修改密码等功能,帮助开发者省去了很多功夫 用于认证的数据表 auth_user User是auth模块中维护用户信息的 ...

  2. 关于adb命令的基本使用

    在我们使用adb命令之前,我们要安装一个安卓模拟器(夜神.逍遥.海马王......),这里以夜神安卓模拟器为准(个人推荐,没用过可以使用夜神模拟器). 进入夜神安卓模拟器官网:https://www. ...

  3. 面试了 6 轮 Google 中国 之后,还是挂了

    去年换工作的时候, 面试了一下 Google (这里说的是 Google 中国哈), 来了个 Google 面试六轮游, 结果是没通过.

  4. Cron表达式,springboot定时任务

    详细请看这篇博客 参考:https://blog.csdn.net/belonghuang157405/article/details/83410197 Cron表达式是一个字符串,字符串以5或6个空 ...

  5. 总结:修改相关postgres用户密码

    1.修改linux系统postgres用户的密码 PostgreSQL会创建一个默认的linux用户postgres,修改该用户密码的方法如下: 步骤一:删除用户postgres的密码 sudo  p ...

  6. 前端Javascript效果汇总

    1.DOM原生动态加载js <script type="text/javascript"> function loadJs(){ //得到html的头部dom var ...

  7. [转] VMware中的Ubuntu无法通过桥接方式上网

    遇到的问题:主机可以上网(使用了代理),VMware设置为桥接方式连网.在主机中可以ping通虚拟机,在虚拟机中也可以ping通主机,可是在虚拟机中始终连接不了因特网. 感谢刘洋同学的博文,“在桥接模 ...

  8. Java——八种基本数据类型(常用类)

    装箱和拆箱 装箱:基本数据类型转为包装类 拆箱:包装类转为基本数据类型 jdk1.5(即jdk5.0)之后的版本都提供了自动装箱和自动拆箱功能 基本数据类型的包装类 举两个例子,看一下 public ...

  9. (八)利用 Profile 构建不同环境的部署包

    接上回继续,项目开发好以后,通常要在多个环境部署,象我们公司多达5种环境:本机环境(local).(开发小组内自测的)开发环境(dev).(提供给测试团队的)测试环境(test).预发布环境(pre) ...

  10. K'ed by TNT team是什么意思?

    参考资料: https://www.zhihu.com/question/319316132 https://www.reddit.com/r/Piracy/comments/9lk20b/tnt_c ...