题目



思路

很明显的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. 批量执行app自动化测试思路设计图

  2. MIT6.S081/6.828 实验1:Lab Unix Utilities

    Mit6.828/6.S081 fall 2019的Lab1是Unix utilities,主要内容为利用xv6的系统调用实现sleep.pingpong.primes.find和xargs等工具.本 ...

  3. [noi.ac省选模拟赛20200606]赌怪

    题目   点这里看题目. 分析   先特判掉\(K=2\)的情况.   首先可以考虑到一个简单 DP :   \(f(i)\):前\(i\)张牌的最大贡献.   转移可以\(O(n^2)\)地枚举区间 ...

  4. Flask URL构建

    Flask URL构建 url_for()函数对于动态构建特定函数的URL非常有用.该函数接受函数的名称作为第一个参数,以及一个或多个关键字参数,每个参数对应于URL的变量部分. 以下脚本演示了如何使 ...

  5. pip安装mysql-connector

    pip install mysql-connector --index-url https://pypi.douban.com/simple

  6. Happens-Before原则

    Java内存模型是通过各种操作来定义的,包括对变量的读/写操作,监视器的加锁和释放操作,以及线程的启动和合并操作.JMM为程序中所有的操作定义了一个偏序关系,称之为Happens-Before.要想保 ...

  7. CSS中可以继承的元素(需要记住)

    可以继承的属性很少,只有颜色,文字,字体间距行高对齐方式,和列表的样式可以继承. 所有元素可继承:visibility和cursor. 内联元素可继承:letter-spacing.word-spac ...

  8. READSJC.md

    这个作业属于哪个课程 软件工程 这个作业要求在哪里 点我 这个作业的目标 介绍自己 作业正文 往下看啦 其他参考文献 空空如也 介绍自己: 我是综合实验班的孙劼成. 天天宅在家里实在是太无聊了,就背背 ...

  9. 升级OPENSSH踩过的坑

    安装三个必要依赖包yum install gcc zlib-devel openssl-devel上传安装包,创建一个/tmp目录下,然后解压,将/etc/ssh/目录移动到本地解压安装包,进入安装目 ...

  10. Java CRC16 MODBUS校验算法实现

    /** * CRC校验算法工具类 */ public class CRCUtil { public static String getCRC(String data) { data = data.re ...