Peter算法小课堂—正整数拆分

这篇具有很好参考价值的文章主要介绍了Peter算法小课堂—正整数拆分。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

大家可能会想:正整数拆分谁不会啊,2年级就会了,为啥要学啊

例题

正整数拆分有好几种,这里我们列举两种讲。

Peter算法小课堂—正整数拆分,动态规划,算法,动态规划

Peter算法小课堂—正整数拆分,动态规划,算法,动态规划

关系

我们看着第一幅图,头向左转90°,记住你看到的图,再来看第二幅图,你会惊奇的发现:第一幅图向左转90°就变成了第二幅图!因此,我们做出来一道题,就能推出另外一题。这种情况我们称之为Ferrers图

例2

我们先思考状态定义:f[i][j]表示把i恰好分成j个正整数的方案数

后面考虑状态转移方程,第一步先列表格。

Peter算法小课堂—正整数拆分,动态规划,算法,动态规划

 我相信聪明的你们已经发现了规律:f[9][4]=1+2+2+1(i=5那行)f[8][3]=1+2+1(i=5那行的前4个)

后面,我们用数学方法推导一下规律:

Peter算法小课堂—正整数拆分,动态规划,算法,动态规划

 因此得到状态转移方程:f[i][j]=f[i-j][1]+f[i-j][2]+……+f[i-j][j],但是时间复杂度为O(n^3)。于是我们进行优化。

我们看到f[i-j][1]+f[i-j][2]+……+f[i-j][j-1]=f[i-1][j-1],为什么因为根据前面的状态转移方程,f[i-1][j-1]等于f[i-j][1]+f[i-j][2]+……+f[i-j][j-1]。最后,我们的状态转移方程变为f[i][j]=f[i-1][j-1]+f[i-j][j]!

最后给个代码,

cin>>n>>m;
for(int i=1;i<=n;i++) f[i][1]=1;
for(int j=2;j<=m;j++)
	for(int i=j;i<=n;i++)
		f[i][j]=f[i-1][j-1]+f[i-j][j];
cout<<f[n][n]<<endl;

变种

太戈编程习题

456. 数的划分

题目描述

将整数n分成k份,且每份不能为空。任意两个方案不能相同(不考虑顺序)。 例如:n=7,k=3,下面三种分法被认为是相同的。 1,1,5;1,5,1;5,1,1; 问有多少种不同的分法。

#include <bits/stdc++.h>
using namespace std;
#define N 210
#define K 16
int n,k,f[N][K];
int main(){
	freopen("partition.in","r",stdin);
	freopen("partition.out","w",stdout);
	cin>>n>>k;
	for(int i=1;i<=n;i++) f[i][1]=1;
	for(int j=2;j<=k;j++)
		for(int i=j;i<=n;i++)
			f[i][j]=f[i-1][j-1]+f[i-j][j];
	cout<<f[n][k]<<endl;
	return 0;
}

457. 训练计划

题目描述

要想成为编程高手,必须独立编程n个小时。作为编程教练,你希望为孩子们设计一套训练计划,将n个小时拆分成若干天完成。已知每天最多安排不能超过k小时,你的训练计划要求每天的训练量不能出现下降。请问一共有多少种训练方案?

 

#include <bits/stdc++.h>
using namespace std;
#define N 350
#define K 34
long long n,k,f[N][K];
int main(){
	freopen("training.in","r",stdin);
	freopen("training.out","w",stdout);
	cin>>n>>k;
	for(long long i=1;i<=n;i++) f[i][1]=1;
	for(long long j=2;j<=k;j++)
		for(long long i=j;i<=n;i++)
			f[i][j]=f[i-1][j-1]+f[i-j][j];
	long long ans=0;
	for(long long i=1;i<=k;i++)
		ans+=f[n][i];
	cout<<ans<<endl;
	return 0;
}

 希望大家可以点个赞、关个住,谢谢o(*^@^*)o文章来源地址https://www.toymoban.com/news/detail-722783.html

到了这里,关于Peter算法小课堂—正整数拆分的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【力扣刷题】整数拆分(动态规划)

    个人简历: 全栈领域新星博主, 万粉博主、 帮助初学者入门,记录自己的学习过程 个人主页:天寒雨落的博客_CSDN博客-C,CSDN竞赛,python领域博主 热门专栏:初学者入门C语言_天寒雨落的博客-CSDN博客   目录 动态规划 整数拆分 题目 思路 代码 执行结果 其基本思想是将待求解

    2024年02月03日
    浏览(44)
  • 整数拆分(力扣)动态规划 JAVA

    给定一个正整数 n ,将其拆分为 k 个 正整数 的和( k = 2 ),并使这些整数的乘积最大化。 返回 你可以获得的最大乘积 。 示例 1: 输入: n = 2 输出: 1 解释: 2 = 1 + 1, 1 × 1 = 1。 示例 2: 输入: n = 10 输出: 36 解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。 提示: 2 = n = 58 里程碑意义 解题思路:

    2024年02月17日
    浏览(46)
  • leetcode 343.整数拆分 198.打家劫舍(动态规划)

       OJ链接 :leetcode 343.整数拆分 代码:  OJ链接 :198.打家劫舍    代码:

    2024年02月05日
    浏览(50)
  • Peter算法小课堂—贪心算法

    课前思考:贪心是什么?贪心如何“贪”? 课前小视频:什么是贪心算法 - 知乎 (zhihu.com) 贪心是一种寻找最优解问题的常用方法。 贪心一般将求解过程分拆成若干个步骤,自顶向下,解决问题 题目描述: 你有一台抓娃娃机器,玩法有点特别:机器会随机给你一排N个娃娃(

    2024年02月05日
    浏览(39)
  • Peter算法小课堂—并查集

    我们先来看太戈编程467题 攀亲戚 题目描述: 最近你发现自己和古代一个皇帝长得很像:都有两个鼻子一个眼睛,你想知道这皇帝是不是你的远方亲戚,你是不是皇亲国戚。目前你能掌握的信息有m条,关于n个人:第i条信息包含两个人的编号ai,bi,表示ai和bi是亲戚。你的编号

    2024年01月18日
    浏览(46)
  • Peter算法小课堂—线性dp

    今天,你读完这篇文章,普及组的动态规划已经可以秒了。 求两个数列的最长公共子序列(Longest Common Subsequence,LCS)的长度。 数列 X 和 Y 的最长公共子序列 Z,是指 Z 既是 X 的子序列,又是 Y 的子序列,而且任意长度超过 Z 的数列 Z∗ 都不符合这个性质。 f[i][j]表示

    2024年04月23日
    浏览(38)
  • Peter算法小课堂—贪心与二分

    题目描述: 有n辆车大甩卖,第i辆车售价a[i]元。有m个人带着现金来申请购买,第i个到现场的人带的现金为b[i]元,只能买价格不超过其现金额的车子。你是大卖场总经理,希望将车和买家尽量多地进行一对一配对,请问最多卖出多少辆车? 贪心法模板: 比如说:每次挑最便

    2024年02月02日
    浏览(40)
  • Peter算法小课堂—树的应用

    开篇先给大家讲个东西,叫vector,有老师称之为“向量”,当然与数学中的向量不一样啊,所以我要称之为“长度可变的数组” 头文件:#include vector 用法:vectorint d; 尾部增加元素:d.push_back(……); 元素个数:d.size() 数组方括号操作:d[i] 尾部删除元素:d.pop_back(……); 清空数

    2024年02月02日
    浏览(41)
  • Peter算法小课堂—自定义容器

    这个算法复杂度为O(nm),显然有更快的算法  但是,这样写有个很危险的错误,如下 运行出来是这样的,  原因很简单,因为set的功能是排序、去重,然而结构体排序要加上“.\\\",所以会报错 改后代码, 那么,回到原题,代码该怎么写呢? 当然这个代码也有高级版,但要升

    2024年02月04日
    浏览(39)
  • 【LeetCode题目详解】第九章 动态规划part03 343. 整数拆分 96.不同的二叉搜索树 (day41补)

    给定一个正整数  n  ,将其拆分为 k 个 正整数 的和(  k = 2  ),并使这些整数的乘积最大化。 返回 你可以获得的最大乘积  。 示例 1: 示例 2: 提示: 2 = n = 58 看到这道题目,都会想拆成两个呢,还是三个呢,还是四个.... 我们来看一下如何使用动规来解决。 # 动态规划 动

    2024年02月10日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包