博客
关于我
Codeforces Round #336 (Div. 1) B. Zuma(区间DP&&记忆化)
阅读量:386 次
发布时间:2019-03-05

本文共 1772 字,大约阅读时间需要 5 分钟。

?????????????

???0?1??????????????????????????????????????????????????????????????

?????????????

??dp[l][r]????[l, r]??????????????????????????dp[l][l] = 0??????????????

?????l??????????????????n???????????????????????

  • ???????a[l] == a[r]????????[l+1][r-1]?????????????????????????????????
  • ????????????????????????????????????????l+1????r-1???????
  • ????????????????????????????????

    ??????

    #include 
    using namespace std;typedef long long ll;int n, dp[501][501], a[501];const int INF = 0x3f3f3f3f;void dfs(int l, int r) { if (l > r) return 1; if (l == r) return dp[l][r] = 1; if (dp[l][r] != INF) return dp[l][r]; int ans = INF; if (a[l] == a[r]) { ans = dp[l+1][r-1]; if (ans == INF) { ans = dfs(l+1, r-1); } } else { ans = min(dp[l+1][r], dp[l][r-1]); if (ans == INF) { ans = min(dfs(l+1, r), dfs(l, r-1)); } } if (ans != INF) { dp[l][r] = ans; } else { dp[l][r] = INF; } return dp[l][r];}int main() { scanf("%d", &n); for (int i = 1; i <= n; ++i) { scanf("%d", &a[i]); } for (int i = 1; i <= n; ++i) { dp[i][i] = 1; } for (int len = 2; len <= n; ++len) { for (int l = 1; l + len - 1 <= n; ++l) { int r = l + len - 1; if (a[l] == a[r]) { dp[l][r] = dp[l+1][r-1]; } else { dp[l][r] = min(dp[l+1][r], dp[l][r-1]); } if (dp[l][r] > 1) { dp[l][r] = INF; } } } printf("%d", dp[1][n]);}

    ????

  • ????????????dp?????dp[l][l] = 1???????????0??
  • ??????????2?n??????????????????????????????????????????????????????
  • ???????????????????????????????????????
  • ??????????????????????????????????????????

    转载地址:http://sgewz.baihongyu.com/

    你可能感兴趣的文章
    opencv笔记(1):图像缩放
    查看>>
    opencv笔记(二十四)——得到轮廓之后找到凸包convex hull
    查看>>
    OpenCV计算点到直线的距离 数学法
    查看>>
    Opencv识别图中人脸
    查看>>
    OpenCV读写avi、mpeg文件
    查看>>
    opencv面向对象设计初探
    查看>>
    OpenCV(1)读写图像
    查看>>
    OpenCV:不规则形状区域中每种颜色的像素数?
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    OpenDaylight融合OpenStack架构分析
    查看>>
    OpenERP ORM 对象方法列表
    查看>>
    openEuler Summit 2022 成功举行,开启全场景创新新时代
    查看>>
    openEuler 正式开放:推动计算多样化时代的到来
    查看>>
    OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_openeuler切换root用户_su:拒绝权限_passwd: 鉴定令牌操作错误---国产瀚高数据库工作笔记001
    查看>>
    OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_踩坑_安装以后系统无法联网_启动ens33网卡---国产瀚高数据库工作笔记002
    查看>>
    OpenFeign 入门与实战
    查看>>
    OpenFeign源码学习
    查看>>
    OpenFeign组件声明式服务调用
    查看>>
    openfeign远程调用不起作用解决_使用Spring Boot的spring.factories进行注入---SpringCloud Alibaba_若依微服务框架改造---工作笔记007
    查看>>
    openfire开发(四)消息拦截器
    查看>>