大厂面试:排列与组合傻傻分不清楚

liftword3个月前 (02-08)技术文章29

一、概念

以a、b、c三个字符来举例。

1)排列:全排列即字符不能重复,第一位有3种选择,第二位有2种选择,第三位有1种选择,所以最后有3*2*1=6种结果。

2)组合:组合不要求三个字符都必须加入结果。

求所有组合也就是abc各个位是否选取的问题,第一位2种可能,第二位2种可能,以此类推,一共有2^n种可能。用0表示不取,1表示选取,这样可以用110这样的形式表示ab。

abc一共的表示形式从0到2^3-1。然后按位与运算,如果结果为1就输出当前位,为0则不输出。


二、代码

1)排列

public class Permutation {
  public static void main(String[] args) {
    char[] array = {'a','b','c'};
    backtrace(array, 0, array.length);
  }
  public static void backtrace(char[] array, int start, int len){
    if(start == len-1){
      for(int i=0; i


2)组合

public class Combination {
  public static void main(String[] args) {
    //待组合的元素
    char[] array = {'a','b','c'};
    //调用获取组合结果函数
    combination(array);
  }
  //求组合结果
  public static void combination(char[] array) {
    int len = array.length;
    //临时变量从0到nbits-1
    int nbits = 1 << len;
    for (int i = 0; i < nbits; ++i) {
    int t;
    for (int j = 0; j < len; j++) {
      t = 1 << j;
      //若t和i的字符相与不为0,则取j位置的字符
      if ((t & i) != 0) {
        System.out.print(array[j]);
      }
    }
    System.out.println();
    }
  }
}




致力于C、C++、Java、Kotlin、Android、Shell、JavaScript、TypeScript、Python等编程技术的技巧经验分享。

若作品对您有帮助,请关注、分享、点赞、收藏、在看、喜欢。您的支持是我们为您提供帮助的最大动力。

相关文章

Python 循环的高阶写法:简洁与高效的代码技巧

在 Python 中,循环的高阶写法通常借助一些内置函数、生成器表达式以及高级的库,能够让代码更加简洁、优雅。以下是几种常见的高阶写法:1. 列表推导式(List Comprehension)列表推导...

用python开发一个炸金花小游戏,注意别玩上瘾了

大家好,我是才哥。众所周知?扑克牌可谓是居家旅行、桌面交友的必备道具,今天我们用 Python 来实现一个类似炸金花的扑克牌小游戏,先来看一下基本的游戏规则。炸(诈)金花又叫三张牌,是在全国广泛流传的...

原理 + 代码|手把手教你用Python实现智能推荐算法

推荐系统将成为未来十年里最重要的变革,社会化网站将由推荐系统所驱动。 --- John Riedl明尼苏达大学教授前言智能推荐和泛的营销完全不同,后者是将产品卖给客户作为最终目标;而智能推荐是以“客户...

Python整数类型(int)详解_python中整数类型

整数就是没有小数部分的数字,Python 中的整数包括正整数、0 和负整数。有些强类型的编程语言会提供多种整数类型,每种类型的长度都不同,能容纳的整数的大小也不同,开发者要根据实际数字的大小选用不同的...

Python学习笔记第一篇(2021年12月14日)——图像的位深度

下面是图片属性1、位深度是什么?位深度是指在记录数字图像的颜色时,计算机实际上是用每个像素需要的位深度来表示的。计算机之所以能够显示颜色,是采用了一种称作“位”( bit ) 的记数单位来记录所表示颜...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用 for 循环或者 while 循环时,如果要在循环体内直接退出循环,可以使用 break 语句。比如计算1至100的整数和,我们用while来实现:sum = 0 x = 1 while True...