`
lknh
  • 浏览: 26115 次
  • 性别: Icon_minigender_1
  • 来自: 广西
社区版块
存档分类
最新评论

回溯法解决整数划分

 
阅读更多
/**
 * 
 * @author chenzhuzuo
 * 回溯法解决数字拆分问题
 * 问题描述:
 * 	整数的分划问题。 
	如,对于正整数n=6,可以分划为: 
	6 
	5+1 
	4+2, 4+1+1 
	3+3, 3+2+1, 3+1+1+1 
	2+2+2, 2+2+1+1, 2+1+1+1+1 
	1+1+1+1+1+1+1 
	现在的问题是,对于给定的正整数n,编写算法打印所有划分。
	用户从键盘输入 n (范围1~10)
程序输出该整数的所有划分。
 *
 *
 *以前做这个题时一直找不到好的思路,在网上也看了一下别人的做法,更多的是使用递归的算法,
 *看了还是不太明白,这几天研究了一下回溯算法,做了几个比较经典的题目,感觉本题可以用求
 *子集和的思路来解决,就试了一下,最后还是做出来了,不过效率不是很高。经过今天的学习
 *,感觉回溯法确实很难懂,但是一旦你弄懂了,回溯法可以说是万能的,真的很好用
 */
public class ShuziChaiFei {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		printResult(6);
	}
	/**
	 * 
	 * @param n对n进行拆分
	 */
	private static void printResult(int n){
		int a[]= new int[n+1];//用于记录每个数出现的个数(1=<i<=n);
		for(int i=0;i<=n;i++){
			a[i]=0;
		}
		int sum=0;
		int k = 1;
		while(k>=1){
			a[k] += 1;
			sum+=k;
			if(sum==n){//如果当前的和等于n则获得一个解,输出
				for(int i=1;i<=k;i++){
					int m=1;
					//a[i]等值表示i在这个解中出现的次数
					while(m<=a[i]){
						if(m==a[i]&&i==k){
							System.out.print(i);
						    m++;
							
						    }
						    else{
						    	System.out.print(i+"+");
								m++;
						    	
						    }
					}
				}
				a[k]++;//继续搜索解空间
				sum+=k;
				System.out.println();
			}
			else if(sum>n){
				sum -= k;
				a[k] -=1;
				k++;
			}
			//当k>n时进行回溯
			if(k>n){
				k--;
				while(a[k]>0){
					sum=sum-a[k]*k;
					k--;
				}
				while(a[k]==0){
					k--;
					if(k<1){
						return;
					}
				}
				sum -= k;
				a[k]--;
				k++;
				
			}
		}
	}

}
0
0
分享到:
评论

相关推荐

    整数划分的回溯法表示

    ### 整数划分的回溯法表示 #### 知识点概述 整数划分问题是一个经典的组合数学问题,指的是将一个正整数拆分成若干个正整数之和的方法数。例如,数字6可以被拆分为`6`, `5+1`, `4+2`, `4+1+1`, `3+3`, `3+2+1`, `3...

    C#整数划分源码 整数划分源码

    下面是一个简单的C#递归回溯法实现整数划分的示例: ```csharp public static void IntegerPartition(int n, List&lt;int&gt; current, int index) { if (n == 0) { Console.WriteLine(string.Join(" + ", current)); ...

    整数划分问题java源码

    动态规划解决整数划分问题的步骤通常如下: 1. 初始化一个二维数组dp,其维度为(n+1) x (n+1),dp[i][j]用于表示数字i是否可以划分为和为j的子集。在初始化时,dp[0][0]设为true,因为表示0可以通过空集划分得到。 ...

    整数划分方法2及代码(有注释)

    总结来说,整数划分方法2是一种利用递归策略解决整数划分问题的算法,尤其适用于需要找出所有可能组合的情况,如循环游戏。在实际应用中,为了优化性能,可以结合动态规划等技术。理解和掌握这种算法对于解决涉及...

    整数划分的vs2010实现

    一种常见的方法是使用回溯法(Backtracking),这是一种试探性的解决问题的方法,通过递归尝试所有可能的分支,当发现无法满足条件时则回溯到上一步,尝试其他路径。在C++中,我们可以创建一个递归函数来处理这个...

    整数划分

    除了回溯法,还可以使用动态规划来解决整数划分问题。动态规划方法通常效率更高,因为它避免了重复计算。我们可以定义一个二维数组dp,其中dp[i][j]表示是否可以将数字i划分成和为j的方式。初始化dp[0][0]为True,...

    0-1背包,prim,矩阵连乘,旅行售货问题,旅行售货员问题-分支算法,棋盘覆盖,整数划分的C++实现

    解决此问题可以采用回溯法,通过尝试放置棋子并检查冲突来逐步构建解决方案。 整数划分问题是指将一组非负整数分成两个或更多个子集,使得每个子集的元素和相等。这是一个困难的优化问题,可以使用回溯、贪心策略...

    计算机算法设计与分析课程设计.doc

    本文档包括了分治法解决棋盘覆盖问题和回溯法解决数字拆分问题两个部分。 分治法解决棋盘覆盖问题 分治法是一种常用的算法设计方法,它的基本思想是将一个复杂的问题分解成两个或更多的相同或相似的子问题,然后再...

    abc.rar_ABC_c++整数规划_整数规划_整数规划 c_规划求解

    解这类问题通常采用搜索算法,如回溯法、动态规划或分支定界法。 对于"输出解"部分,它可能包含了程序运行的结果,即如何划分这些整数以及得到的最优解。这部分内容对于理解算法的实际效果和验证其正确性至关重要。...

    深优先搜索与回溯算法PPT学习教案.pptx

    回溯法是一种通过尝试所有可能的解决方案,并在发现不符合条件的解时撤销最近的决策,退回一步并尝试其他路径的算法。它是DFS的一个变种,具有“试探-撤销-再试探”的特点。在解决迷宫问题中,回溯法可以模拟实际的...

    计算机算法设计和分析课程设计汇本.doc

    在课程设计中,学生需要使用回溯法解决数字拆分问题,即找到所有可能的方式将一个整数拆分为若干个整数的和。回溯法通过构建可能的解决方案并逐步回溯,以避免无效的搜索路径。在分析和实现过程中,学生需要理解和...

    suanfafenxi.rar_动态规划法

    描述中提到的“五个经典的算法分析”暗示了这个压缩包不仅限于动态规划,还可能涵盖了递归法、回溯法、分治法以及整数变换和圆的最小排列问题,这些都是计算机科学和算法设计中重要的方法。 1. **动态规划法**:...

    运动员最佳配对问题(习题514)定义.pdf

    同样可以使用回溯法解决,但需要控制搜索深度以避免搜索空间过大。search(int dep)函数用于递归地构造子集,同时记录搜索过程中的时间以控制搜索深度。 【整数变换问题】 整数变换问题要求从整数n通过一系列f=3i和...

    算法竞赛入门经典授课教案第7章_暴力求解法.doc

    课程按照简单枚举、枚举排列、子集生成、回溯法和隐式图搜索划分,每部分深入讲解相关知识点。 总的来说,暴力求解法虽然不是最优化的解题策略,但它提供了一种直观的思路,尤其在问题规模较小或找不到更好算法的...

    典型算法的数据结构及C++代码实现

    "回溯法解决部落卫队问题"可能是通过搜索所有可能的排列组合,找出满足特定条件的解决方案。在C++实现中,通常会用到深度优先搜索(DFS)和剪枝技术,以减少无效的搜索路径。 五、分支定界法 分支定界法用于求解...

    算法设计_排序

    常见的算法有回溯法和递归法,可以用于解决组合问题和某些搜索问题。 4. **整数划分**: 整数划分问题是数学优化的一个经典问题,目标是在给定正整数n和一组正整数a1, a2, ..., ak的情况下,找出所有可能的非空子...

    武汉理工大学复试算法设计程序

    4. "递归与分治--整数划分问题"可能需要考生理解和实现如何将一个正整数划分为若干个正整数的和,使得这些整数的乘积最大。这个问题可以通过动态规划或递归与分治的方法来解决。 5. "减治法--插入排序"是基础排序...

    常用算法设计方法(C语言)

    回溯法是一种试探性的解决问题方法,当发现当前选择无法达到目标时,会撤销选择,尝试其他路径。在C语言中,回溯法常用于解决组合优化问题,如八皇后问题、数独填充等。它结合了深度优先搜索和剪枝策略,以避免无效...

    acm题库及其详细算法

    在整数划分问题中,我们需要使用动态规划算法来解决。在 Counting 问题中,我们需要使用计数排序算法来解决。 在矩阵连乘问题中,我们需要使用动态规划算法来解决。在最长公共子序列问题中,我们需要使用动态规划...

    东北大学算法设计课程实验源码

    本篇文章旨在详细介绍东北大学算法设计课程实验源码中包含的三种基础且核心的算法思想:分治法、回溯法、以及动态规划,并探讨如何在实际编程和问题解决中灵活运用这些算法。 首先,让我们来深入探讨分治法。分治法...

Global site tag (gtag.js) - Google Analytics