博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java实现排列组合
阅读量:2197 次
发布时间:2019-05-02

本文共 1713 字,大约阅读时间需要 5 分钟。

基本概念

阶乘

在介绍排列组合前首先要介绍阶乘,因为很多排列组合的运算都是要用上阶乘。阶乘的定义如下:一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,并且0的阶乘为1。自然数n的阶乘写作n!。

n!=1×2×3×...×n。阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n

排列组合

排列组合是组合学最基本的概念。所谓排列,就是指从给定个数的元素中取出指定个数的元素进行排序。组合则是指从给定个数的元素中仅仅取出指定个数的元素,不考虑排序。下面是整理后的资料:

名称 排列 组合
定义 从n个不同的元素中取出m个元素,按一定顺序进行排序 从n个不同的元素中取出m个元素,不考虑排序
基本写法 Amn A n m Cmn C n m
计算公式 Amn=n(n1)...(nm+1) A n m = n ( n − 1 ) . . . ( n − m + 1 ) , Amn=n!m! A n m = n ! m ! Ann=n! A n n = n ! , A0n=1 A n 0 = 1 Cmn=n(n1)...(nm+1)m! C n m = n ( n − 1 ) . . . ( n − m + 1 ) m ! Cmn=n!m!(nm)! C n m = n ! m ! ( n − m ) ! , C0n=1 C n 0 = 1 Cnn=1 C n n = 1
关系 Amn=Cmn×Amm A n m = C n m × A m m Cmn=AmnAmm C n m = A n m A m m
性质 Amn=n×Am1n1 A n m = n × A n − 1 m − 1 Cmn=Cmnm C n m = C n − m m , Cmn+1=Cmn+Cm1n C n + 1 m = C n m + C n m − 1

实现代码

阶乘

/**     * 非递归版阶乘     * @param n     * @return     */    public int factorial(int n){        if(n==0){            return 1;        }else{            int result=1;            for(int i=1;i<=n;i++){                result*=i;            }            return result;        }    }    /**     * 递归版阶乘     * @param n     * @return     */    public int factorial(int n){        if(n==0){            return 1;        }else{            return n*factorial(n-1);        }    }

排列组合

/**     * 排列     * @param m 上标     * @param n 下标     * @return     */    public int permutation(int m,int n){        if(n==0){            return 1;        }        int result=1;        for(int k=n;k>=n-m+1;k--){            result*=k;        }        return result;    }    /**     * 组合     * @param m 上标     * @param n 下标     * @return     */    public int combination(int m,int n){        return permutation(m,n)/permutation(m,m);    }

转载地址:http://droub.baihongyu.com/

你可能感兴趣的文章
【LEETCODE】67-Add Binary
查看>>
【LEETCODE】7-Reverse Integer
查看>>
【LEETCODE】165-Compare Version Numbers
查看>>
【LEETCODE】299-Bulls and Cows
查看>>
【LEETCODE】223-Rectangle Area
查看>>
【LEETCODE】12-Integer to Roman
查看>>
【学习方法】如何分析源代码
查看>>
【LEETCODE】61- Rotate List [Python]
查看>>
【LEETCODE】82- Remove Duplicates from Sorted List II [Python]
查看>>
【LEETCODE】86- Partition List [Python]
查看>>
【LEETCODE】147- Insertion Sort List [Python]
查看>>
【算法】- 动态规划的编织艺术
查看>>
用 TensorFlow 让你的机器人唱首原创给你听
查看>>
对比学习用 Keras 搭建 CNN RNN 等常用神经网络
查看>>
深度学习的主要应用举例
查看>>
word2vec 模型思想和代码实现
查看>>
怎样做情感分析
查看>>
用深度神经网络处理NER命名实体识别问题
查看>>
用 RNN 训练语言模型生成文本
查看>>
RNN与机器翻译
查看>>