算法学习->整数拆分问题
动态规划典型题目/
00 题目
将正整数n无需拆分为最大数为k的拆分方案有多少种?
要求所有的拆分方案不重复。
示例:
输入:n=5,k=5
输出:(5,5)=7
示例分析:
5=5
5=4+1
5=3+2
5=3+1+1
5=2+2+1
5=2+1+1+1
5=1+1+1+1+1
所以一共七种。
01 思路
01-1 类型
求解这一问题的思路有很多,在这里是想作为动态规划的例题进行分析。所以采用动态规划。
01-2 算法
使用动态规划,最重要的是状态转移方程
简单说就是当前状态对下一状态,依据限制条件,进行决策的函数。
来想一下,n和k的关系:
n=1或者k=1时,显然 f(n,k)=1;
n<k时,有 f(n,k)=f(n,n);
n=k时,f(n,n)=f(n,n-1)+1
//即将k降一次的感觉,因为这种情况必有一种拆分是他自己,比如上面的5,5
n>k时,我们考虑一下,会有两种大的情况:
第一种,n的拆分里有k,那这一大类其实相当于f(n,k)=f(n-k,k)
第二种,n的拆分里没k,那就是拆分里所有数都比k小,即n的(k-1)的拆分,即f(n,k)=f(n,k-1);
02 代码
这样的代码就很好实现。
典型动态规划实现的话,就只有嵌套循环和if-else循环。
1 //求解n的k拆分
2 #include<stdio.h>
3 #include<string.h>
4 #define MAXN 500
5 int dp[MAXN][MAXN];
6 void Split(int n, int k){
7 for(int i = 1; i <= n; i++){
8 for(int j = 1; j <= k; j++){
9 if(i == 1 || j == 1){
10 dp[i][j] = 1;
11 }
12 else if(i < j){
13 dp[i][j] = dp[i][i];
14 }
15 else if(i == j){
16 dp[i][j] = dp[i][j-1]+1;
17 }
18 else{
19 dp[i][j] = dp[i][j-1] + dp[i-j][j];
20 }
21 }
22 }
23 }
24 int main(){
25 int n=5,k=5;
26 memset(dp, 0, sizeof(dp));
27 Split(n,k);
28 printf("(%d, %d)=%d",n,k,dp[n][k]);
29 return 0;
30 }
31
因为这个问题是递归的,所以可以采用递归来写,解决过程是自顶向下的。当然就在递归过程中将算过的子问题放进dp数组,在后续dp不等0时就是此前已经算过了,直接return就行。
这种方法也叫备忘录法
1 #include<stdio.h>
2 #include<string.h>
3 #define MAXN 500
4 int dp[MAXN][MAXN];
5 int dpf(int n, int k){
6 if(dp[n][k] != 0)return dp[n][k];
7 if(n == 1 || k == 1){
8 dp[n][k] = 1;
9 return dp[n][k];
10 }
11 else if(n < k){
12 dp[n][k] = dpf(n, n);
13 return dp[n][k];
14 }
15 else if(n == k){
16 dp[n][k] = dpf(n, k-1)+1;
17 return dp[n][k];
18 }
19 else{
20 dp[n][k] = dpf(n, k-1)+dpf(n-k, k);
21 return dp[n][k];
22 }
23 }
24 int main(){
25 int n=5,k=5;
26 memset(dp, 0, sizeof(dp));
27 printf("(%d, %d)=%d",n,k,dpf(n,k));
28 return 0;
29 }
算法学习->整数拆分问题的更多相关文章
- 算法学习之C语言基础
算法学习,先熟悉一下C语言哈!!! #include <conio.h> #include<stdio.h> int main(){ printf(+); getch(); ; ...
- C / C++算法学习笔记(8)-SHELL排序
原始地址:C / C++算法学习笔记(8)-SHELL排序 基本思想 先取一个小于n的整数d1作为第一个增量(gap),把文件的全部记录分成d1个组.所有距离为dl的倍数的记录放在同一个组中.先在各组 ...
- LeetCode 343. 整数拆分(Integer Break) 25
343. 整数拆分 343. Integer Break 题目描述 给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化. 返回你可以获得的最大乘积. 每日一算法2019/5/2 ...
- LeetCode 343.整数拆分 - JavaScript
题目描述:给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化. 返回你可以获得的最大乘积. 题目分析 题目中"n 至少可以拆分为两个正整数的和",这个条件说 ...
- DSP算法学习-过采样技术
DSP算法学习-过采样技术 彭会锋 2015-04-27 23:23:47 参考论文: 1 http://wr.lib.tsinghua.edu.cn/sites/default/files/1207 ...
- HDU 4651 Partition(整数拆分)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4651 题意:给出n.求其整数拆分的方案数. i64 f[N]; void init(){ f[0 ...
- Python之路,Day21 - 常用算法学习
Python之路,Day21 - 常用算法学习 本节内容 算法定义 时间复杂度 空间复杂度 常用算法实例 1.算法定义 算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的 ...
- LightOJ 1336 Sigma Function(数论 整数拆分推论)
--->题意:给一个函数的定义,F(n)代表n的所有约数之和,并且给出了整数拆分公式以及F(n)的计算方法,对于一个给出的N让我们求1 - N之间有多少个数满足F(x)为偶数的情况,输出这个数. ...
- LightOJ 1341 Aladdin and the Flying Carpet(整数拆分定理)
分析:题目并不难理解,就是一些细节上的优化需要我们注意,我在没有优化前跑了2000多MS,优化了一些细节后就是400多MS了,之前还TLE了好几次. 方法:将整数拆分为质因子以后,表达为这样的形式,e ...
随机推荐
- 在Unity中渲染一个黑洞
在Unity中渲染一个黑洞 前言 N年前观看<星际穿越>时,被其中的"卡冈图雅"黑洞所震撼.制作团队表示这是一个最贴近实际的黑洞效果,因为它是通过各种科学理论实现的.当 ...
- 地心地固坐标系(ECEF)与站心坐标系(ENU)的转换
目录 1. 概述 2. 原理 2.1. 平移 2.2. 旋转 2.3. 总结 3. 实现 4. 参考 1. 概述 我在<大地经纬度坐标与地心地固坐标的的转换>这篇文章中已经论述了地心坐标系 ...
- 在开源项目或项目中使用git建立fork仓库
前言: vector我们经常使用,对vector里面的基本函数构造函数.增加函数.删除函数.遍历函数我们也会用到.其中在使用遍历之后erase删除元素过程中,会出现一种删除最后一个元素破坏了迭代器的情 ...
- js 改变this指向的三种方法 bind call apply
先了解下bind call apply 的注意点 bind 需要手动调用 第一个参数 this 要指向的对象,后面是 散列的参数 call 不需要手动调用 第一个参数 this 要指向的对象,后面是 ...
- UOJ 2021 NOI Day2 部分题解
获奖名单 题目传送门 Solution 不难看出,若我们单个 \(x\) 连 \((0,x),(x,0)\),两个连 \((x,y),(y,x)\) ,除去中间过对称轴的一个两个组,就是找很多个欧拉回 ...
- 👊 Spring技术原理系列(7)带你看看那些可能你还不知道的Spring特性技巧哦!
前提介绍 本文主要介绍相关Spring框架的一些新特性问题机制,包含了一些特定注解方面的认识. @Lazy可以延迟依赖注入 @Lazy注解修饰在类层面! @Lazy @Service public c ...
- Centos7 python3环境搭建 兼容python2.7
Centos7 python3环境搭建 兼容python2.7 安装前提依赖 yum install openssl-devel bzip2-devel expat-devel gdbm-devel ...
- PyCharm永久破解方法,2021最新版本!!!
1,下载破解补丁(已更新到2021.1版本): 关注微信公众号<程序员的时光>,回复破解补丁即可: 下载补丁文件 jetbrains-agent.jar 和importat.txt文件并将 ...
- 【UE4 C++】 启动 / 关闭外部exe、开启虚拟键盘
启动/关闭外部exe 引擎自带 FPlatformProcess::CreateProc() FPlatformProcess::TerminateProc() windows api ShellEx ...
- 进阶区forgotg攻防世界
攻防世界进阶区--forgot 前言,这题中看不中用啊宝友!!! 1.查看保护 第一反应就是蛮简单的,32位. 2.获取信息(先运行程序看看) 装的可以,蛮多的东西. 但是就是中看不中用 3.ida ...