采用分治思想,很多书都有。。。
这里只是引用一下,因为有很几个算法需要基于全排列算法
所以写在这里还是有点必要的
递推公式
Perm(R)=r1Perm(R1)+r2Perm(R2)+...+rnPerm(Rn);
不懂的话看书~~
package www.viking.com.algorithm;
/**
*
* @author viking
*
* 用分治的方法
* 有n个字符,f(n)表示n个数的全排列
* f(n-n1)表示从n个字符中排除n1之后n-1字符的排列
*
* f(n)=f(n-n1)+f(n-n2)+....f(n-nn);
*/
public class Perm {
public static void main(String[] agrs) {
char[] s = "123".toCharArray();
int count = perm(0, s);
System.out.println(count);
}
public static int perm(int begin, char[] s) {
if (begin == s.length) {
System.out.println(String.valueOf(s));
return 1;
}
int count = 0;
for (int i = begin; i < s.length; i++) {
switchChar(begin, i, s);
count += perm(begin + 1, s);
switchChar(begin, i, s);
}
return count;
}
public static void switchChar(int i, int k, char[] s) {
char temp = s[i];
s[i] = s[k];
s[k] = temp;
}
}
分享到:
相关推荐
生成这些字符的不重复的全排列,并将结果打印到标准输出上。 【输入形式】 从标准输入上读入一个由字母、数字组成的字符串,字符串的长度小于100,其中包含重复的字符。 【输出形式】 向标准输出印...
当输入元素中存在重复时,处理全排列问题会变得更为复杂。C#作为.NET框架下的主要编程语言,提供了丰富的数据结构和算法支持来解决这类问题。本篇文章将深入探讨如何使用C#解决全排列重复问题,并提供一种有效的实现...
算法分析课程作业,C语言编写,可能需要用input.txt输入,有重复数字的全排列代码
1、输入n个数(不重复),求n个数字的全排列 如:n=3 全排列的数字为 1 2 3 则输出 123 132 213 231 321 312 2、输入n和k(n》=k)求n个数字的(n,k)排列 如n=3,k=2 输入的三个数位1 2 3 则输出 12 13 21 23 31...
总结,局部搜索在全排列问题中的应用主要体现在使用递归策略生成排列,但这种方法对于大规模问题效率低下,且处理重复元素时存在问题。对于矩阵最小值问题,全排列提供了所有可能的组合,但计算量随矩阵大小呈指数级...
以下是C语言实现5个数全排列的基本步骤: 1. 定义一个数组,存储5个待排列的数。 2. 编写一个递归函数,接收当前已排列的子数组和未排列的子数组作为参数。 3. 在递归函数中,如果未排列的子数组为空,说明所有排列...
n个有重复元素全排列:无重复的全排列为序列头元素与所有元素进行交换共n种情况,每种情况的后n-1位元素构成新的序列。 重复以上过程。因为有重复元素,想要序列不重复:(1)需要保证序列头元素与其余元素一次交换...
为方便起见,用123来示例下。123的全排列有123、132、213、231、312、321这六种。...因此可以知道——全排列就是从第一个数字起每个数分别与它后面的数字交换。找到这个规律后,递归的代码就很容易写出来了:
根据给定文件的信息,本文将深入探讨如何使用回溯法来输出自然数1到n的所有不重复排列(即n的全排列)。同时,还将提供一个Java实现的具体示例。 ### 回溯法简介 回溯法是一种通过尝试解决离散和组合问题的方法,...
标题 "N个数全排列的非递归算法" 涉及的是计算机科学中的经典问题——全排列。全排列是指从n个不同元素中取出m(m≤n)个元素,按照一定的顺序排成一列的所有可能组合。在这个场景中,非递归算法指的是不依赖递归...
这样我们也得到了在全排列中去掉重复的规则——去重的全排列就是从第一个数字起每个数分别与它后面非重复出现的数字交换。用编程的话描述就是第i个数与第j个数交换时,要求[i,j)中没有与第j个数相等的数。下面给出...
3. **回溯法与深度优先搜索**:全排列问题可以通过回溯法和深度优先搜索(DFS)解决,每次选择一个未使用过的元素,然后递归地对剩余元素进行全排列,最后回溯撤销选择。 以上策略可以有效地减少不必要的计算,提高...
总结,这个问题是关于使用C语言编程解决一个排列组合问题,通过三重循环生成所有可能的三位数,同时利用条件判断保证数字的唯一性。这个过程体现了程序设计基础、数据结构基础和C语言语法等多方面的知识。
通过学习这个源码示例,你可以掌握易语言中的递归和回溯技术,这对于理解和解决其他涉及排列组合的问题也非常有帮助。同时,这也是提高易语言编程技能的一个好机会,因为实践是学习编程最有效的方式之一。
在C#编程中,我们经常会遇到需要解决排列组合问题,比如本题所示的例子:如何用1、2、3、4这四个数字组成互不相同且无重复数字的三位数,并计算总数以及列举出所有可能的组合。这个问题属于组合数学中的全排列问题,...
这里,我们面对的挑战是:给定数字1、2、3、4,如何通过编程方法来找出所有可能的互不相同且无重复数字的三位数。 在进行详细的解释之前,我们可以先考虑一下这个问题的基本思路。首先,考虑到三位数的特点,百位、...
全排列算法是计算机科学中一个基础且重要的问题,主要涉及到数组或序列的所有可能排列组合的生成。本主题将深入探讨两种解决全排列问题的方法:分治法和回溯法。 一、分治法求解全排列 分治法是一种解决复杂问题的...
去重全排列的递归实现 去掉重复数字的 全排列的 递归实现
【问题描述】输入整数N( 1 ),生成从1~N所有整数的全排列。 【输入形式】输入整数N。 【输出形式】输出有N!行,每行都是从1~N所有整数的一个全排列,各整数之间以空格分隔。各行上的全排列不重复。输出各行遵循...