码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C#,排列组合的堆生成法(Heap’s Algorithm for generating permutations)算法与源代码


    1 排列组合的堆生成法

    堆生成算法用于生成n个对象的所有组合。其思想是通过选择一对要交换的元素,在不干扰其他n-2元素的情况下,从先前的组合生成每个组合。

    下面是生成n个给定数的所有组合的示例。

    示例:

    输入:1 2 3

    输出:1 2 3

    2 1 3

    3 1 2

    1 3 2

    2 3 1

    3 2 1

    2 算法

    算法生成(n-1)!前n-1个元素的排列,与其中每个元素相邻的最后一个元素。这将生成以最后一个元素结尾的所有置换。

    如果n为奇数,则交换第一个和最后一个元素,如果n为偶数,则交换第i个元素(i是从0开始的计数器)和最后一个元素,并重复上述算法,直到i小于n。

    在每次迭代中,算法将生成以当前最后一个元素结尾的所有组合。

    3 源程序

    using System;
    using System.Collections;
    using System.Collections.Generic;

    namespace Legalsoft.Truffer.Algorithm
    { <

  • 相关阅读:
    数据治理资料整理合集
    2023研究生数学建模D题思路
    FAlphaBlend——Unreal中的插值助手
    JAVA毕业设计vue校园菜鸟驿站管理系统计算机源码+lw文档+系统+调试部署+数据库
    【接口协议】基于 FPGA 的 HMDI 彩条显示实验
    C现代方法(第13章)笔记——字符串
    蓝桥杯每日一题2023.10.27
    docker形式简易部署kibana
    电脑技巧:原版Windows系统与Ghost系统的区别
    Grial UI Kit 4发布,版本4中的新增功能
  • 原文地址:https://blog.csdn.net/beijinghorn/article/details/124898321
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号