ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

ObjectARX递归AcArray数组组合函数

2021-02-15 12:34:54  阅读:270  来源: 互联网

标签:arr 递归 combination ObjectARX arrs AcArray 函数


ObjectARX递归AcArray数组组合函数

图文by edata  , 转载注明出处 http://www.cnblogs.com/edata 

ObjectARX QQ群: 630401507 (仅ObjectARX)
AutoCAD.net QQ群: 193522571 (ObjectARX\AutoLisp\AutoCAD.net)

 

 

函数源码

 

 为了通用,写为函数模板.代码如下

    // 指定组合数量递归函数模板(1 2 3) n=1 => (1) (2) (3) n=2 => (1 2) (1 3) (2 3)
    template <class T>
    static AcArray<T> combination(T arr,int m)
    {
        AcArray<T> arrs;
        if (arr.length()>0 && m > 0)
        {
            T cdr=arr;
            cdr.removeFirst();            
            AcArray<T> tmparrs1=combination(cdr,m-1);
            if (tmparrs1.isEmpty() && m ==1)
            {
                T tmp;
                tmp.append(arr.first());
                arrs.append(tmp);
            }
            else
            {
                for (int i=0;i<tmparrs1.length();i++)
                {                
                    tmparrs1.at(i).insertAt(0,arr.first());
                }
                arrs.append(tmparrs1);                    
            }
            AcArray<T> tmparrs2 = combination(cdr,m);
            if (!tmparrs2.isEmpty())
            {
                arrs.append(tmparrs2);
            }                        
        }
        return arrs;
    }

    //全部组合函数模板(1 2 3) => (1) (2) (3) (1 2) (1 3) (2 3) (1 2 3)
    template <class T>
    static AcArray<T> combination(T arr)
    {    
        AcArray<T> arrs;        
        for (int i=1;i<=arr.length();i++)
        {
            //调用递归
            AcArray<T> tempArray =combination(arr,i);
            arrs.append(tempArray);            
        }
        return arrs;
    }

注意:第二个依赖第一个函数.

使用实例

使用AcGeIntArray做示例,只要是使用AcArray构成的类型,都可以.比如arx自带的AcDbObjectArray,自己使用AcArray定义的类型都可以...

        //此处使用ARX自带的AcGeIntArray做示例
        AcGeIntArray a;
        //第一种方式,
        AcArray<AcGeIntArray> arrs;
        //第二种方式,使用typedef定义一个类型别名
        //typedef AcArray<AcGeIntArray> AcGeIntArrays;
        //AcGeIntArrays arrs;

        //初始化数组
        for (int i=0;i<3;i++)
        {
            a.append(i+1);
        }

        //调用组合函数        
        arrs=combination(a);        
        //输出组合结果
        acutPrintf(_T("\n组合结果\n"));
        for (int i=0;i<arrs.length();i++)
        {
            AcGeIntArray tmp=arrs.at(i);
            for (int j=0;j<tmp.length();j++)
            {
                acutPrintf(_T("%d "),tmp.at(j));
            }
            acutPrintf(_T("\n"));
        }

组合函数结果图

标签:arr,递归,combination,ObjectARX,arrs,AcArray,函数
来源: https://www.cnblogs.com/edata/p/14403502.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有