当前位置: 首页 > news >正文

算法基础之整数划分

整数划分

  • 核心思想: 计数类dp

背包做法

  • f[i][j] 表示 取 1 – i 的物品 总容量为j的选法数量

    • f[i][j] = f[i-1][j] + f[i-1][j-v[i]] +f[i-1][j-2v[i]] +f[i-1][j-3v[i]] +……+f[i-1][j-kv[i]]

    • f[i][j-v[i]] = f[i-1][j-v[i]] +f[i-1][j-2v[i]] +f[i-1][j-3v[i]] +……+f[i-1][j-kv[i]]

      • f[i][j] = f[i-1][j] + f[i][j-v[i]]; (本题中 v[i] = i)

      • 在这里插入图片描述

      •   #include<iostream>#include<cstring>#include<algorithm>using namespace std;const int N = 1010 , mod = 1e9 + 7;;int n;int f[N];int main(){cin>>n;f[0] = 1;  //f[0] 没有数 方法是1种for(int i=1;i<=n;i++)for(int j=i;j<=n;j++)//f[i][j - i] = f[i][j - i] + f[i][j - 2] + ... + f[i][j - k]//f[j-i] f[j] = (f[j] + f[j - i]) % mod;cout<<f[n];}
        

dp做法

  • f[i][j] 表示总和为i 总共j个数的方案数量

    • 将f[i][j] 分为 最小值是1的方案最小值大于1的方案 两部分 (不重不漏)

      • 最小值是1: 在集合中–1 –> f[i-1][j-1] 总和为i-1 个数为j-1
      • 最小值大于1 : 将集合总每个数-1 –> f[i-j][j] 总和为i-j 个数为j
    • f[i][j] = f[i-1][j-1] + f[i-j][j]

      • 在这里插入图片描述
    • 结果 : res = f[n][1] + f[n][2] +f[n][3] + … + f[n][n] (1个数的方案+2个数的方案+ … +n个数的方案)

      •   #include<iostream>#include<cstring>#include<algorithm>using namespace std;const int N = 1010 , mod = 1e9 + 7;;int n;int f[N][N];int main(){cin>>n;f[0][0] = 1;for(int i=1;i<=n;i++){for(int j=1;j<=i;j++)  //总和为i 个数最多为i{f[i][j] = (f[i-1][j-1] + f[i - j][j] ) % mod;    }}int res = 0;for(int i=1;i<=n;i++) res = (res + f[n][i]) % mod;cout<<res;}
        
http://www.lryc.cn/news/268476.html

相关文章:

  • 关于“Python”的核心知识点整理大全47
  • Android 8.1 设置USB传输文件模式(MTP)
  • 模型量化 | Pytorch的模型量化基础
  • adb和logcat常用命令
  • 千巡翼X4轻型无人机 赋能智慧矿山
  • 【Android 13】使用Android Studio调试系统应用之Settings移植(一):编译服务器的配置、AOSP源码的下载、编译、运行
  • 【1】Docker详解与部署微服务实战
  • C# JsonString转Object以及Object转JsonString
  • 华为OD机试真题-中文分词模拟器-2023年OD统一考试(C卷)
  • 【并发设计模式】聊聊 基于Copy-on-Write模式下的CopyOnWriteArrayList
  • OpenCV中使用Mask R-CNN实现图像分割的原理与技术实现方案
  • 论文阅读《Rethinking Efficient Lane Detection via Curve Modeling》
  • Leetcode—2660.保龄球游戏的获胜者【简单】
  • ubuntu服务器上安装KVM虚拟化
  • SpreadJS 集成使用案例
  • 单挑力扣(LeetCode)SQL题:534. 游戏玩法分析 III(难度:中等)
  • 【OpenCV】告别人工目检:深度学习技术引领工业品缺陷检测新时代
  • VR全景图片制作时有哪些技巧,VR全景图片能带来哪些好处
  • 【VUE】Flask+vue-element-admin前后端分离项目发布到linux服务器操作指南
  • django的gunicorn的异步任务执行
  • KEPServerEX 6 之【外篇-2】PTC-ThingWorx服务端软件安装 PostgreSQL本地安装
  • websocket 介绍
  • 【IoT网络层】STM32 + ESP8266 +MQTT + 阿里云物联网平台 |开源,附资料|
  • 数据分析工具 Top 8
  • AI 换脸的新时代:没有显卡也可以使用的AI换脸工具
  • 3.Python中的循环结构
  • 机器学习之BP神经网络精讲(Backpropagation Neural Network(附案例代码))
  • 安全生产人员定位系统助企业实现智能化管理,提高生产安全性和效率
  • 动态规划 多源路径 字典树 LeetCode2977:转换字符串的最小成本
  • Hadoop集群找不到native-hadoop