题目



思路

很明显的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. Linux: 如何分割文件,不再被 4G 大小限制了

    单文件 4G 限制 FAT32 4G 限制 百度网盘超出 4G 限制 单文件分割与合并 单文件,如:archive.tar.gz 分割 split -b 3000M -d -a 1 archive.t ...

  2. c#撸的控制台版2048小游戏

    1.分析 最近心血来潮,突然想写一个2048小游戏.于是搜索了一个在线2048玩玩,熟悉熟悉规则. 只谈核心规则:(以左移为例) 1.1合并 以行为单位,忽略0位,每列依次向左进行合并,且每列只能合并 ...

  3. 看到这些常见的android面试题,你慌了吗?

    最近参加了一些Android工程师岗位的面试,总结了一些常见的考点,希望能帮到正在面试的你(答案还在整理中)! 1.Java调用函数传入实际参数时,是值传递还是引用传递? 2.单例模式的DCL方式,为 ...

  4. Android学习笔记.9.png格式图片

    .9.png可以保证图片在合适的位置进行局部拉伸,避免了图片全局缩放造成的图片变形问题.AS提供了制作点9图片的便捷入口,并且会检查你的.9图是否有不合理的拉伸区域. 选中图片点击create 9-p ...

  5. 论logstash的玩法(ELK)

    本篇文章采用的采用的是logstash-7.7.0版本,主要从如下几个方面介绍 1.logstash是什么,可以用来干啥 2.logstash的基本原理是什么 3.怎么去玩这个elk的组件logsta ...

  6. S7-1200视频教程: S7-1200的功能与特点-跟我做 - 2/112

    S7-1200视频教程: S7-1200的功能与特点-跟我做 - 2/112 观看连接: http://www.elearning.siemens.com.cn/video/Course/201105 ...

  7. k8s的两种网络方案与多种工作模式[flannel与calico]

    k8s的两种网络方案与多种工作模式 1. Flannel: flannel有三种工作模式: 1. vxlan(隧道方案) 2. host-gw(路由方案) 2. udp(在用户态实现的数据封装解封装, ...

  8. .Net Core微服务入门全纪录(六)——EventBus-事件总线

    前言 上一篇[.Net Core微服务入门全纪录(五)--Ocelot-API网关(下)]中已经完成了Ocelot + Consul的搭建,这一篇简单说一下EventBus. EventBus-事件总 ...

  9. vue-cli按装 和vue创建项目

    安装 创建

  10. Halcon斑点分析官方示例讲解

    官方示例中有许多很好的例子可以帮助大家理解和学习Halcon,下面举几个经典的斑点分析例子讲解一下 Crystals 图中显示了在高层大气中采集到的晶体样本的图像.任务是分析对象以确定特定形状的频率. ...