如何编写从M中选N的组合数程序,一个不用递归方法设计,一个用递归方法设计

本文提供了一种从m个不同元素中选取N个元素的所有可能组合的方法,包括递归和非递归两种实现方式,并通过示例代码展示了这两种算法的具体实现。
     看到有人写帖子问如果从m个数组中取N个原始的算法,要求一个是递归的,一个不是递归的。
递归的解法:(比较笨)
void getn(int a[], int b[] , int m, int n, int index,int lastindex)
{
        
int i = lastindex + 1;
        
if(index == n )
        {
                
int x;
                
for(x = 0 ; x  < n ;x ++)
                {
                        printf(
" %d ",a[b[x]]);
                }
                printf(
" ");
                
return ;
        }
        
while( i  < m)
        {
                b[index] 
= i;
                getn(a,b,m,n,index 
+ 1,i);
                i 
++ ;
        }

 非递归的解法:
 
void agen(int a[],int m, int n) /* from m get n */
{
        
int i ,j  ;
        
int b[100= {0}; /* big then n */
        i 
= j = 0;
        
while(b[0]  < m ) {
                
while( i  < m) {
                        
if(j == n - 1 ) {
                                
int x ;
                                
for( x = 0 ; x  < n ; x ++) {
                                        printf(
" %d ",a[b[x]]);
                                }
                                printf(
" ");
                        } 
else {
                                j 
++;
                        }
                        i 
++;
                        b[j] 
= i;

                }
                
do {
                        j 
--;
                        b[j] 
++ ;
                } 
while(b[j] >= m );
                i 
= b[j] ;
        }

  测试的主程序:

int main()
{
        int a[10] = {0, 1,2,3,4,5,6,7,8,9};
        int b[20] ={0};
        getn(a,b,10,5,0,-1);
        agen(a,10,5);
        return 0;
}
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值