• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 5, comments - 10, trackbacks - 0, articles - 0
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
            作者:flysnwoxg
            c++編譯器模板解析確實(shí)很強(qiáng)大。基本上可以把編譯器看做是一個(gè)虛擬機(jī),c++模板源代碼就是被執(zhí)行的腳本代碼。
            基本上你可以在編譯期實(shí)現(xiàn)任何算法。
            下面是一個(gè)按照從小到大,然后從大到小對(duì)數(shù)值對(duì)排序的程序,程序使用了冒泡排序,排序在編譯期完成。
            例如程序的原始輸入為: ((5,6),(1,5),(3,4))
            將被從小到大排序?yàn)?nbsp; ((1,5),(3,4),(5,6))
            然后被從大到小排序?yàn)?nbsp; ((5,6),(3,4),(1,5))


            //author:flysnowxg 
            #include "stdio.h"
            //用模板表示類(lèi)型,模板的實(shí)例化表示對(duì)象(如pait_t<1,2> 表示(1,2)這樣的兩個(gè)值的對(duì)象)
            template<int _first,int _second>
            struct pair_t{
                static const int first=_first;
                static const int second=_second;
                static void print(){printf("%d %d",first,second);}
            };

            //計(jì)算兩個(gè)不同的pair_t類(lèi)型的實(shí)例的小于關(guān)系
            template <typename T1,typename T2
            struct  less_t{
                static const int first_le=T1::first<T2::first;
                static const int first_eq=T1::first==T2::first;
                static const int second_le=(first_eq&&(T1::second<T2::second));
                static const int result=first_le || second_le;
            };

            //計(jì)算兩個(gè)不同的pair_t類(lèi)型的實(shí)例的大于關(guān)系
            template <typename T1,typename T2
            struct  greate_t{
                static const int result=!less_t<T1,T2>::result;
            };

            struct null_t;
            //類(lèi)型列表
            template <typename T1,typename T2struct list_t;
            template <typename T>
            struct list_t<T,null_t>{
                typedef T value;
                typedef null_t next;
            };
            template <typename T1,typename T2,typename T3>
            struct list_t<T1,list_t<T2,T3> >
            {
                typedef T1 value;
                typedef list_t<T2,T3next
            };
            #define list_t1(e1list_t<e1,null_t>
            #define list_t2(e1,e2list_t<e1,list_t1(e2)>
            #define list_t3(e1,e2,e3list_t<e1,list_t2(e2,e3)>
            #define list_t4(e1,e2,e3,e4list_t<e1,list_t3(e2,e3,e4)>
            #define list_t5(e1,e2,e3,e4,e5list_t<e1,list_t4(e2,e3,e4,e5)>
            #define list_t6(e1,e2,e3,e4,e5,e6list_t<e1,list_t5(e2,e3,e4,e5,e6)>
            #define list_t7(e1,e2,e3,e4,e5,e6,e7list_t<e1,list_t6(e2,e3,e4,e5,e6,e7)>
            #define list_t8(e1,e2,e3,e4,e5,e6,e7,e8list_t<e1,list_t7(e2,e3,e4,e5,e6,e7,e8)>
            #define list_t9(e1,e2,e3,e4,e5,e6,e7,e8,e9list_t<e1,list_t8(e2,e3,e4,e5,e6,e7,e8,e9)>
            #define list_t10(e1,e2,e3,e4,e5,e6,e7,e8,e9,e10list_t<e1,list_t9(e2,e3,e4,e5,e6,e7,e8,e9,e10)>

            //遞歸打印類(lèi)型列表中每個(gè)類(lèi)型的值
            template<typename Tstruct print_t;
            template<typename T>
            struct print_t<list_t<T,null_t>>
            {
                typedef typename T result;
                static void print(){
                    printf("\nelem::");
                    result::print();
                }
            };
            template<typename T1,typename T2>
            struct print_t<list_t<T1,T2>>
            {
                typedef typename T1 result;
                static void print(){
                    printf("\nelem::");
                    result::print();
                    print_t<T2>::print();
                }
            };

            //冒泡排序算法
            template<typename T,template <typename,typenameclass CompareTstruct sort_t;
            template<typename T,template <typename,typenameclass CompareT>
            struct sort_t<list_t<T,null_t> ,CompareT>{
                typedef list_t<T,null_tsort_head;
                typedef T least_elem;
                typedef null_t remainder;
                typedef list_t<T,null_tresult;
            };
            template<typename T1,typename T2,template <typename,typenameclass CompareT>
            struct sort_t<list_t<T1,T2>,CompareT>{
                template<bool _b_swapstruct swap_t{
                    typedef list_t<T1,T2result;
                };
                template<> struct swap_t<false>{
                    typedef list_t<typename T2::value,list_t<T1,typename T2::next> > result;
                };
                static const int order=!CompareT<T1,T2::value>::result;
                typedef typename swap_t<order>::result sort_head;//假如CompareT是less_t,將開(kāi)頭兩個(gè)元素中大的放前面,小的放后面
                typedef typename sort_t<typename sort_head::next,CompareT>::least_elem least_elem;//假如CompareT是less_t,獲取列表中最小的元素
                typedef list_t<typename sort_head::value,typename sort_t<typename sort_head::next,CompareT>::remainderremainder;//去掉末尾那個(gè)最小元素
                typedef list_t<least_elem,typename sort_t<remainder,CompareT>::resultresult;//將最小元素和剩余已經(jīng)排好序的元素鏈表組成一個(gè)新鏈表
            }; 
            int main(int argccharargv[])
            {
                typedef pair_t<50,6> e1_t;
                typedef pair_t<9,10> e2_t;
                typedef pair_t<1,2> e3_t;
                typedef pair_t<7,8> e4_t;
                typedef pair_t<3,4> e5_t;
                typedef pair_t<-6,4> e6_t;

                typedef list_t6(e1_t,e2_t,e3_t,e4_t,e5_t,e6_tdate_t;
                printf("原始數(shù)據(jù):");
                print_t<date_t>::print();

                typedef sort_t<date_t,less_t>::result data_ta;
                printf("\n\n從小到大:");
                print_t<data_ta>::print();

                typedef sort_t<date_t,greate_t>::result data_tb;
                printf("\n\n從大到小:");
                print_t<data_tb>::print();
             
            最后的輸出:
            原始數(shù)據(jù):
            elem::50 6
            elem::9 10
            elem::1 2
            elem::7 8
            elem::3 4
            elem::-6 4
            從小到大:
            elem::-6 4
            elem::1 2
            elem::3 4
            elem::7 8
            elem::9 10
            elem::50 6
            從大到小:
            elem::50 6
            elem::9 10
            elem::7 8
            elem::3 4
            elem::1 2
            elem::-6 4

            Feedback

            # re: 使用元編程在編譯期對(duì)數(shù)值進(jìn)行排序  回復(fù)  更多評(píng)論   

            2014-10-17 10:18 by hellmonky
            很久沒(méi)有看到博客更新了,從tinyscheme注釋開(kāi)始關(guān)注您,希望能看到更多相關(guān)的主題,非常感謝您的分享!

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            久久国产乱子伦精品免费午夜| 99精品久久久久久久婷婷| 久久精品国产亚洲AV不卡| 国产视频久久| 亚洲AV日韩精品久久久久久| 国产一久久香蕉国产线看观看| 久久中文精品无码中文字幕| 久久这里有精品| 亚洲国产精品久久久久网站 | 婷婷久久久亚洲欧洲日产国码AV| 亚洲αv久久久噜噜噜噜噜| 91精品国产高清久久久久久国产嫩草 | 97热久久免费频精品99| 精品国产婷婷久久久| 久久www免费人成看片| 精品欧美一区二区三区久久久 | 久久A级毛片免费观看| 国产精品九九久久免费视频| 伊人久久精品无码二区麻豆| 性高湖久久久久久久久AAAAA| 久久99亚洲网美利坚合众国| 免费一级欧美大片久久网| 99久久精品毛片免费播放| 一本一道久久综合狠狠老| 免费精品国产日韩热久久| 亚洲精品99久久久久中文字幕| 久久亚洲高清观看| 欧美一区二区三区久久综| 2019久久久高清456| 欧美日韩精品久久久免费观看| 久久亚洲中文字幕精品一区四 | 国产色综合久久无码有码| 国产精品嫩草影院久久| 国产成人精品久久一区二区三区av | 久久久久女人精品毛片| 久久婷婷国产剧情内射白浆 | 91精品免费久久久久久久久| 91精品国产高清91久久久久久| 久久发布国产伦子伦精品| 久久精品日日躁夜夜躁欧美| 久久久久久久精品妇女99 |