- 浏览: 1999211 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (651)
- ACE (35)
- BAT (9)
- C/C++ (116)
- fast-cgi (14)
- COM (27)
- python (59)
- CGI (4)
- C# (2)
- VC (84)
- DataBase (29)
- Linux (96)
- P2P (6)
- PHP (15)
- Web (6)
- Memcached (7)
- IME输入法 (11)
- 设计模式 (2)
- 搜索引擎 (1)
- 个人情感 (4)
- 笔试/面试 (3)
- 一亩三分地 (33)
- 历史 (2)
- 地理 (1)
- 人物 (3)
- 经济 (0)
- 不仅仅是笑哦 (43)
- 小故事大道理 (2)
- http://www.bjdsmyysjk120.com/ (0)
- http://www.bjdsmyy120.com/ (0)
- 它山之石可以攻玉 (15)
- 大学生你关注些什么 (28)
- 数据恢复 (1)
最新评论
-
luokaichuang:
这个规范里还是没有让我明白当浏览器上传文件时,STDIN的消息 ...
FastCGI规范 -
effort_fan:
好文章!学习了,谢谢分享!
com技术简介 -
vcell:
有错误os.walk(strPath)返回的已经是全部的文件和 ...
通过python获取目录的大小 -
feifeigd:
feifeigd 写道注意:文章中的CPP示例第二行 #inc ...
ATL入门:利用ATL编写简单的COM组件 -
feifeigd:
注意:文章中的CPP示例第二行 #include " ...
ATL入门:利用ATL编写简单的COM组件
简单算法:
从前往后(或者从后往前)每次交换一个位置。当存在一个到达最后位置时,需要调整整个数组的位置。将所有的0(1)的位置向后整体移动一位。
直到结束。
#include <iostream> #include <assert.h> #include <new> using namespace std; void PrintArr(const int* pnArr, const int nLen); int Combin(const int m, const int n); bool IsEndofCombin(const int* pnArr, const int m, const int n); bool ChangeArr(int* pnArr, const int m, const int n); int main() { int m = 0; int n = 0; while (true) { cout << "please input m:"; cin >> m; cout << "please input n:"; cin >> n; Combin(m, n); } return 0; } void PrintArr(const int* pnArr, const int nLen) { assert(pnArr && nLen > 0); int i = 0; for (i = 0; i < nLen; i++) { if (pnArr[i] > 0) { cout << char('A' + i); } } cout << endl; } bool IsEndofCombin(const int* pnArr, const int m, const int n) { assert(pnArr && m > 0 && n > 0 && m >= n); bool bResvr = n > m / 2 ? true : false; if (m == n) { return false; } int i = 0; if (bResvr) { for (i = 0; i < m - n; i++) { if (pnArr[i] > 0) { return false; } } } else { for (i = n; i < m; i++) { if (pnArr[i] < 0) { return false; } } } return true; } bool AdjustArr(int* pnArr, const int m, const int n) { assert(pnArr && m > 0 && n > 0 && m >= n); if (m == n) { return false; } bool bResvr = n > m / 2 ? true : false; int i = 0; int j = 0; if (bResvr) { for (i = 0; i < m - n; i++) { if (pnArr[i] > 0) { break; } } //如果交换完成 if (i >= m -n ) { return false; } //开始交换 if (pnArr[0] > 0) { return false; } //找到需要移动的位置,从此位置向前移动一位 for (i = m - 1; i >= 0; i--) { if (pnArr[i] <= 0) { break; } } for (j = 0; j < m; j++) { pnArr[j] = 1; } for (j = 0; j < m - n; j++) { pnArr[--i] = 0; } return true; } else { for (i = 0; i < m - n; i++) { if (pnArr[m - i - 1] <= 0) { break; } } //交换完毕 if (i >= m - n) { return false; } //开始交换 if (pnArr[m - 1] <= 0) { return false; } //找到需要移动的位置,从此位置向后移动一位 for (i = 0; i < m; i++) { if (pnArr[i] > 0) { break; } } for (j = 0; j < m; j++) { pnArr[j] = 0; } for (j = 0; j < n; j++) { pnArr[++i] = 1; } return true; } return true; } bool ChangeArr(int* pnArr, const int m, const int n) { assert(pnArr && m > 0 && n > 0 && m >= n); if (m == n) { return false; } bool bResvr = n > m / 2 ? true : false; int i = 0; int nPlace = 0; int nTime = 0; if (bResvr) { nPlace = 0; for (nTime = 0; nTime < m - n; nTime++) { for (i = nPlace; i < m; i++) { if (pnArr[i] <= 0) { //change if (i > nPlace) { int nTmp = pnArr[i]; pnArr[i] = pnArr[i - 1]; pnArr[i - 1] = nTmp; return true; } else { nPlace++; break; } } } } } else { nPlace = m - 1; for (nTime = 0; nTime < m - n; nTime++) { for (i = nPlace; i >= 0; i--) { if (pnArr[i] > 0) { //change if (i < nPlace) { int nTmp = pnArr[i]; pnArr[i] = pnArr[i + 1]; pnArr[i + 1] = nTmp; return true; } else { nPlace--; break; } } } } } return false; } //get n combin from m numbers int Combin(const int m, const int n) { assert(m > 0 && n > 0 && m >= n); int* pnArr = new(nothrow) int[m]; if (NULL == pnArr) { return -1; } //int aray memset(pnArr, 0, sizeof(int) * m); int i = 0; for (i = 0; i < m; i++) { pnArr[i] = i < n ? 1 : 0; } int nCount = 0; PrintArr(pnArr, m); nCount++; while (true) { if (!ChangeArr(pnArr, m, n)) { cout << "total count:" << nCount << endl; break; } PrintArr(pnArr, m); nCount++; //adjust value if (AdjustArr(pnArr, m, n)) { PrintArr(pnArr, m); nCount++; } } return 0; }
发表评论
-
Berkeley DB 使用经验总结
2012-08-27 14:41 3024作者:陈磊 NoSQL是现在互联网Web2.0时代备受 ... -
嵌入式数据库系统Berkeley DB
2012-08-27 14:37 1473前言 UNIX/LINUX平台下的数据库种类非常多 ... -
C语言中标准输入流、标准输出流、标准错误输出流
2011-06-13 14:32 9197C语言中标准输入流、标准输出流、标准错误输出流 在 ... -
Rsync 实现原理
2011-05-12 20:06 8250Rsync 实现原理 前言 关于rsync的原始文档 ... -
c++简单的虚函数测试
2011-04-27 14:25 967#include <iostream> u ... -
C++文件行查找
2011-04-26 14:10 1350#include <iostream> # ... -
c++偏特化简单示例
2011-04-13 11:17 2106c++偏特化 // temp1.c ... -
GDB调试精粹及使用实例
2011-03-16 14:06 1079GDB调试精粹及使用实例 一:列文件清单 1. ... -
简单的ini文件解析
2011-02-12 16:36 1570int GetKeyVal(const string s ... -
scanf族函数高级用法
2011-01-25 16:00 2481如何解释 fscanf(fd,&quo ... -
使用scons替代makefile(1)
2011-01-25 11:58 3638早在多年前我刚开始接触linux下的C程序时,经常被makef ... -
使用scons替代makefile(2)
2011-01-25 11:57 3526本篇文章接着上一篇进一步介绍scons的使用方法,主要介绍静态 ... -
使用scons替代makefile(3)
2011-01-25 11:55 4774在上两篇文章中已经简单介绍了用scons编译库文件,可执行程序 ... -
C 支持动态添加测试数据的测试代码
2011-01-13 17:22 1077/下面的定义为了支持可扩增。 //当需要增加一个新的测试用列 ... -
Linux下Makefile的automake生成
2010-12-28 16:55 1046******************helloworld.c* ... -
SCons笔记(详细版)
2010-12-23 16:11 103711. 基本使用 SConstruct文件就功能而言相当于Ma ... -
scons 学习
2010-12-23 11:14 2107scons 学习 作者:Sam(甄峰) sam_code@h ... -
scons随笔
2010-12-22 20:20 4637scons随笔 Scons是新一代的软件构件工具,或者说ma ... -
Scons在linux下的安装和使用
2010-12-21 11:59 3196因为正在用的一个开源软件需要的Developm ... -
UDP编程的服务器 Linux
2010-10-22 18:44 1281UDP编程的服务器端一般步骤是: ...
相关推荐
qt c++ 排列组合 实现 没分的联系本人索要
PHP实现多种类型的排列组合算法,PHP多种方式实现排列组合算法。非常有用,欢迎下载。
排列组合算法实现,支持模板类。支持重复数的排列。算法采用递归方法,简单易懂。
主要介绍了C#实现排列组合算法的完整实例,文中实例主要展示了排列循环方法和排列堆栈方法,需要的朋友可以参考下
本资源附带文档解释了排列组合算法的实现和原理。其中排列算法是基于递归实现的,组合算法是基于高效的位移法实现的。代码是使用Java版实现的。
小小wintc程序 计算排列组合代吗 用递归写的 呵呵
从n个数组中取出所有排列组合(Java实现)
排列组合生成算法的python实现。实现方法参考了维基百科中的combination和permutation词条。 使用方法: python combinations.py #按字典序生成6中选3的组合(数字代码中可以调整) python arrangement.py #按字典序...
本文实例讲述了php通过排列组合实现1到9数字相加都等于20的方法。分享给大家供大家参考。具体实现方法如下: <?php set_time_limit(0); /* 函数说明:huoqu_zhuhe($eq,$jiashu,$isone=0) 参数说明:$eq---几个数...
6位数,共有几种排列组合的算法,java实现
数字排列组合是个经典的算法问题,它很通俗易懂,适合不懂业务的人学习,我们通过它来发现和运用并行计算的优势,可以得到一个很直观的体会,并留下深刻的印象。问题如下: 请写一个程序,输入M,然后打印出M个...
组合数学之排列组合生成算法,很好的学习组合排列算法的资料
用递归实现排列组合,并能够结合解决P(m,n)问题
只需改变里面一处数据,就可以根据自己需要,执行输出n个数中取m个数的所有组合。
该算法用来实现组合排列,并输出排列个数和排列结果!
Java排列组合_组合算法,利用list及set的无序性, 通过递归实现,不同于以往的排列组合 自娱自乐
这段程序是为了验证google的一个面试题些的。... 大概意思如下: 有一组点,知道其坐标值。 有一只笔可以用来画出点。笔画出点的时间很快,可以忽略不计,但是笔移动比较耗时。 1....(若画笔的初始位置在左下角) 2....
c++课程设计,排列组合,算法 超级简单的,