• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 浅谈c语言中一种典型的排列组合算法

浅谈c语言中一种典型的排列组合算法

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了浅谈c语言的位运算,浅谈c语言,c语言全排列算法,c语言排列组合算法,c语言全排列递归算法等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

c语言中的全排列算法和组合数算法在实际问题中应用非常之广,但算法有许许多多,而我个人认为方法不必记太多,最好只记熟一种即可,一招鲜亦可吃遍天

全排列:

#include<stdio.h>

void swap(int *p1,int *p2)

{

int t=*p1;

*p1=*p2;

*p2=t;

}

void permutation(int a[],int index,int size)

{

if(index==size)

{

for(int i=0;i<size;i++)

printf("%d ",a[i]);

printf("\n");

}

else

{

for(int j=index;j<size;j++)

{

swap(&a[j],&a[index]);

permutation(a,index+1,size);//此处用到递归思想

swap(&a[j],&a[index]);

}

}

}

int main()

{

int n;

scanf("%d",&n);

int a[n];

for(int i=0;i<n;i++)

a[i]=i+1;

permutation(a,0,n);

return 0;

}
</div>

 

组合:

#include<stdio.h>

void combine(int n,int m,int a[],int b[],const int M)

{

for(int j=n;j>=m;j--)

{

b[m-1]=j-1;

if(m>1)combine(j-1,m-1,a,b,M);//用到了递归思想

else

{

for(int i=M-1;i>=0;i--)printf("%d ",a[b[i]]);

printf("\n");

}

}

}

int main()

{

int n,m;

scanf("%d%d",&n,&m);

int a[n];int b[m];

for(int i=0;i<n;i++)

a[i]=i+1;

const int M=m;

combine(n,m,a,b,M);

}
</div>

以上这篇浅谈c语言中一种典型的排列组合算法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅谈c语言中一种典型的排列组合算法
  • 浅谈C语言共用体和与结构体的区别
  • 浅谈C语言函数调用参数压栈的相关问题
  • 浅谈C语言之字符串处理函数
  • 浅谈c语言中类型隐性转换的坑
  • 浅谈时间戳与日期时间互转C语言
  • 浅谈C语言的字符串分割
  • 浅谈C语言编程中程序的一些基本的编写优化技巧
  • 浅谈C语言中的强符号、弱符号、强引用和弱引用
  • 浅谈C语言中结构体的初始化

相关文章

  • 2017-05-28基于SVN源码服务器搭建(详细教程分析)
  • 2017-05-28C++编程中逗号运算符和条件运算符的使用方法讲解
  • 2017-05-28C++中引用&与取地址&的区别分析
  • 2017-05-28详解C++编程中的条件判断语句if-else与switch的用法
  • 2017-05-28c++中for双循环的那些事
  • 2017-05-28C++中关键字Struct和Class的区别
  • 2017-05-28c语言网络编程-标准步骤(比较简单)
  • 2017-05-28C++函数的嵌套调用和递归调用学习教程
  • 2017-05-28详解在C++中显式默认设置的函数和已删除的函数的方法
  • 2017-05-28希尔排序算法的C语言实现示例

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 16种C语言编译警告(Warning)类型的解决方法
    • C语言中二维数组指针的简要说明
    • C语言小程序 如何判断三角型类型
    • C++实现将一个字符串中的字符替换成另一个字符串的方法
    • 基于C语言char与unsigned char的区别介绍
    • C语言实现对bmp格式图片打码
    • 浅谈C#中List<T>对象的深度拷贝问题
    • C++中用new创建二维数组和指针数组实例代码
    • 二叉查找树的插入,删除,查找
    • 解析C++中的for循环以及基于范围的for语句使用

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有