热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

HOJ1402:整数分解与组合优化问题研究

HOJ1402题目涉及整数划分的经典问题,旨在通过具体的实例提升对组合数学的理解和应用能力。该问题不仅考察了基本的数学原理,还要求对算法优化有深入的认识,以高效解决大规模数据下的整数分解与组合优化挑战。

HOJ1402 整数划分

http://acm.hit.edu.cn/hoj/problem/view?id=1402

【题目描述】

整数划分是一个经典的问题。希望这道题会对你的组合数学的解题能力有所帮助。

Input

每组输入是两个整数n和k。(1 <&#61; n <&#61; 50, 1 <&#61; k <&#61; n)

Output

对于每组输入&#xff0c;请输出六行。

第一行&#xff1a; 将n划分成若干正整数之和的划分数。
第二行&#xff1a; 将n划分成k个正整数之和的划分数。
第三行&#xff1a; 将n划分成最大数不超过k的划分数。
第四行&#xff1a; 将n划分成若干奇正整数之和的划分数。
第五行&#xff1a; 将n划分成若干不同整数之和的划分数。
第六行&#xff1a; 打印一个空行。

Sample Input

5 2

Sample Output

7
2
3
3
3

Hint:

  1. 将5划分成若干正整数之和的划分为&#xff1a; 5, 4&#43;1, 3&#43;2, 3&#43;1&#43;1, 2&#43;2&#43;1, 2&#43;1&#43;1&#43;1, 1&#43;1&#43;1&#43;1&#43;1
  2. 将5划分成2个正整数之和的划分为&#xff1a; 3&#43;2, 4&#43;1
  3. 将5划分成最大数不超过2的划分为&#xff1a; 1&#43;1&#43;1&#43;1&#43;1, 1&#43;1&#43;1&#43;2, 1&#43;2&#43;2
  4. 将5划分成若干奇正整数之和的划分为&#xff1a; 5, 1&#43;1&#43;3, 1&#43;1&#43;1&#43;1&#43;1
  5. 将5划分成若干不同整数之和的划分为&#xff1a; 5, 1&#43;4, 2&#43;3

 

【算法分析】

  

本题相当于5个小问题&#xff0c;首先来看最容易做的第5个小问题&#xff1a;将n划分成若干不同整数之和的划分数。则是一个典型的背包装物品问题&#xff0c;把问题转化一下&#xff0c;即一个容量为n的背包&#xff0c;重量分别为1n的物品各一个&#xff0c;求用若干物品将背包填满的方案总数。

利用动态规划的思想&#xff0c;很容易得到方程F[I,J] &#61; F[I-1,J] &#43;F[I-1,J-I]&#xff0c;其中F[I,J]表示从前I个物品中用若干个组成的总重量为J的方案总数&#xff0c;转移时要保证F[I-1,J-I]有意义。答案为F[n,n]&#xff0c;时间复杂度为O(n2)

对于前3个小问题可以归结为一个问题&#xff0c;即第2个小问题&#xff1a;把将n划分成k个正整数之和的划分数。

为了避免重复&#xff0c;我们需要按照不下降的顺序进行排列。我们形象地可以把nk份自然数划分看作n块积木堆成k列&#xff0c;那么不妨设这n块积木从左到右被堆成“阶梯状”。比如&#xff0c;下图表示的是3104份自然数划分。

 

而将该图旋转90度&#xff0c;可以很容易想出一种状态表示方法。

 

F[I,J,K]表示把J划分成I份最大为K的划分方案数&#xff0c;则有F[I,J,K] &#61; F[I-1,J-K,L]&#xff0c;其中L &#61; 1..K。时间复杂度为O&#xff08;n2k2&#xff09;。

而如果观察第一个图&#xff0c;我们还可以得到一种状态表示方式。设F[I,J]表示把I划分成J份的划分方案数&#xff0c;则有F[I,J] &#61; F[I-J,K] &#xff0c;其中K &#61; 0..J。时间复杂度为O&#xff08;nk2&#xff09;。

又由于F[I,J]&#61;F[I-J,K]&#xff08;K &#61; 0..J&#xff09;&#61;F[I-J,K]&#xff08;K &#61; 0..J-1&#xff09;&#43;F[I-J,J] &#61; F[I-1,J-1]&#43;F[I-J,J]&#xff0c;这样就把时间复杂度降为O&#xff08;nk&#xff09;。从另外一个角度想&#xff0c;我们在第一个图中“截去底边”&#xff0c;由于存在一个划分方案中含1的情况&#xff0c;我们无法确定在“截去底边”之后要把I-J分为几个数&#xff0c;那么不妨将划分方案中含1的情况单独列出来讨论&#xff0c;直接得到F[I,J] &#61; F[I-1,J-1]&#43;F[I-J,J]

对于第1个小问题的答案是∑F[N,I]&#xff08;I &#61; 1..N&#xff09;&#xff0c;第2个小问题的答案显然是F[N,K]&#xff0c;而第3个小问题的答案则是∑F[N,I]&#xff08;I &#61; 1..K&#xff09;&#xff0c;考虑上面旋转90度之后的图&#xff0c;你会发现&#xff0c;F[N,I]集合中的最高高度均为I&#xff0c;即将n划分成最大数为I的方案数。

最后来看第4个小问题&#xff0c;就是第2个小问题的分奇偶版本&#xff0c;那么设F[I,J]表示把I划分成J个奇数的划分方案数&#xff0c;G[I,J] 表示把I划分成J个偶数的划分方案数。那么还是用“截去底边”的思想&#xff0c;显然有G[I,J] &#61; F[I-J,J]。但F[I,J]却不是直接等于G[I-J,J]&#xff0c;因为这里又存在一个划分方案中含1的情况&#xff0c;同样将划分方案中含1的情况单独列出来讨论&#xff0c;则有F[I,J] &#61; G[I-J,J] &#43; F[I-1,J-1]。最后的答案就是∑F[N,I]&#xff08;I &#61; 1..N&#xff09;&#xff0c;时间复杂度为O(n2)

 

#include
#include

#include
using namespace std;const int maxn &#61; 51;int n,k;
int f[maxn][maxn], g[maxn][maxn];
int f1[maxn][maxn], f2[maxn][maxn];int main () {int i, j;int ans1, ans2, ans3, ans4, ans5;f1[0][0] &#61; 1;for (i &#61; 1; i )for (j &#61; 1; j <&#61; i; j &#43;&#43;)f1[i][j]&#61;f1[i-j][j]&#43;f1[i-1][j-1];f[0][0] &#61; g[0][0] &#61; 1;for (i &#61; 1; i )for (j &#61; 1; j <&#61; i; j &#43;&#43;){g[i][j] &#61; f[i - j][j];f[i][j] &#61; f[i - 1][j - 1] &#43; g[i - j][j];}for (i &#61; 0; i )f2[i][0] &#61; 1;for (i &#61; 1; i )for (j &#61; 1; j ){f2[i][j] &#61; f2[i - 1][j];if (j - i >&#61; 0)f2[i][j] &#43;&#61; f2[i - 1][j - i];}while (scanf ("%d %d", &n, &k) !&#61; EOF){ans1 &#61; ans2 &#61; ans3 &#61; ans4 &#61; ans5 &#61; 0;for (i &#61; 1; i <&#61; n; i &#43;&#43;)ans1 &#43;&#61; f1[n][i];ans2 &#61; f1[n][k];for (i &#61; 1; i <&#61; k; i &#43;&#43;)ans3 &#43;&#61; f1[n][i];for (i &#61; 1; i <&#61; n; i &#43;&#43;)ans4 &#43;&#61; f[n][i];ans5 &#61; f2[n][n];printf ("%d\n%d\n%d\n%d\n%d\n\n", ans1, ans2, ans3, ans4, ans5);}return 0;
}

 



推荐阅读
  • 算术表达式分析与解析技术初探
    本文初步探讨了算术表达式的分析与解析技术,针对作者在职业转型过程中发现自身算法基础薄弱的问题,决定在接下来的三个月内,系统地学习和掌握常用数据结构与算法,以提升个人技术能力。研究内容不仅涵盖了基本的算术表达式解析方法,还深入讨论了其在实际应用中的优化策略,为相关领域的进一步研究奠定了基础。 ... [详细]
  • HDU 2067 动态规划与卡特兰数的应用分析
    题目描述:小兔的叔叔从外地旅行归来,给她带回了一份礼物。小兔兴奋地回到自己的房间,迫不及待地拆开礼物,发现是一副棋盘,虽然有些失望,但很快她便对这个新奇的物品产生了浓厚的兴趣。本文将通过动态规划和卡特兰数的应用,详细分析该问题的求解方法,并探讨其背后的数学原理。 ... [详细]
  • 在Java中,一个类可以实现多个接口,但是否能够继承多个类则存在限制。本文探讨了Java中实现多继承的方法及其局限性,详细分析了通过接口、抽象类和组合等技术手段来模拟多继承的策略,并讨论了这些方法的优势和潜在问题。 ... [详细]
  • [Offer收割]编程竞赛第8轮 A 小Ho的完美主义倾向
    题目链接:小Ho的完美主义倾向题目描述:小Ho在一条直线型的街道上漫步。这条街道由若干块长度为L的石板铺设而成,因此每隔L的距离就会出现一道石板间的接缝。小Ho对这些规律排列的接缝产生了浓厚的兴趣,他决定研究如何在这条街道上行走,以满足自己对完美路径的追求。本题要求在给定的约束条件下,计算出小Ho能够实现其目标的所有可能方案数。 ... [详细]
  • 微软发布紧急安全更新,所有Windows 10版本均面临影响!
    微软于周五紧急发布了两项安全更新,旨在解决Windows 10所有版本中Windows Codecs库和Visual Studio Code应用存在的安全隐患。此次更新是继本周初发布的月度例行安全补丁之外的额外措施,凸显了这些问题的紧迫性和重要性。这些漏洞可能被攻击者利用,导致系统权限提升或远程代码执行等严重后果。建议用户尽快安装更新,以确保系统的安全性。 ... [详细]
  • 7.2 利用关系运算符与表达式进行数值对比分析
    在C语言中,关系运算符和表达式是进行数值对比分析的基础工具。本节详细介绍了真值的概念及其在编程中的应用,包括布尔类型(_Bool)的引入,以及关系运算符的优先级。通过具体示例,展示了如何在 `while` 循环中使用关系表达式来控制程序流程。这些内容对于理解和编写高效的条件判断逻辑至关重要。 ... [详细]
  • AngularJS uirouter模块下的状态管理机制深入解析
    本文深入探讨了 AngularJS 中 ui-router 模块的状态管理机制。通过详细分析状态配置、状态转换和嵌套状态等核心概念,结合实际案例,帮助开发者更好地理解和应用这一强大工具,提升单页面应用的开发效率和用户体验。 ... [详细]
  • PAT甲级 1068 寻找更多硬币 (30分) 01背包问题与路径优化
    PAT甲级 1068 寻找更多硬币 (30分) 01背包问题与路径优化 ... [详细]
  • 超链接作为网页间的重要连接方式,不仅是信息流动的关键通道,还极大地提升了网络资源的可访问性和互联性。通过超链接,用户能够便捷地在不同网站和页面之间跳转,获取所需信息,促进了互联网内容的广泛传播与高效利用。 ... [详细]
  • 安装Qt时,Qt\Qt5.x.x文件夹下自动安装了example文件夹,其中包含了大量的示例。这里根据Examples\Qt-5.5\widgets\t ... [详细]
  • C/C++利用栈和队列实现停车场管理系统【C++教程】
    数据结构的课程设计一般都不是很好理解,今天小编为大家总结了一下c和c++版本的常见栈和队列的的停车场管理程序,需要 ... [详细]
  • CatchThatCowTimeLimit:50002000MS(JavaOthers)MemoryLimit:3276832768K(JavaOt ... [详细]
  • 问题背景:在使用Struts2注解实现ZIP文件下载功能时,由于InputStream未正确关闭,导致Tomcat服务器异常终止。重启后,系统抛出`java.io.EOFException`错误。具体表现为,在文件下载过程中,如果请求未正常完成或客户端提前中断连接,未关闭的InputStream会占用资源,最终导致服务器资源耗尽,触发异常。为解决此问题,建议在代码中确保InputStream在使用完毕后能够及时且正确地关闭,以避免资源泄露和服务器崩溃。 ... [详细]
  • 通过采用JSON数据格式,能够高效且精确地获取用户的实时地理位置信息,为各类位置服务应用提供可靠的数据支持。该方法不仅简化了数据交换流程,还提高了地理信息处理的准确性和效率,适用于移动应用、导航系统及物联网设备等多种场景。 ... [详细]
  • 如何在C++中定位数组中特定数字的最后一个位置 ... [详细]
author-avatar
8o断情戒爱o8
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有