• <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 - 183,  comments - 10,  trackbacks - 0

            排列與組合
            問題描述:
            對(duì)一個(gè)字符串,求出其所有的全排列情況和所有的組合情況。
            例如字符串 abc
            其所有的全排列是 abc, acb, bac, bca, cab, cba
            其所有的組合是:a, b, c, ab, ac, bc, abc

            全排列:
            固定前面的元素,對(duì)后面的進(jìn)行遞歸求解,求解后,恢復(fù)之前的狀態(tài),并將后面的元素與前面的進(jìn)行交換。
            代碼描述:

            void Permutation(char* pStr, char* pBegin);

            void Permutation(char* pStr)
            {
                  Permutation(pStr, pStr);
            }

            void Permutation(char* pStr, char* pBegin)
            {
                  
            if(!pStr || !pBegin)
                        
            return;
                        
                  
            if(*pBegin == '\0')
                  {
                        printf(
            "%s\n", pStr);
                  }
                  
            else
                  {
                        
            for(char* pCh = pBegin; *pCh != '\0'++ pCh)
                        {
                              
            char temp = *pCh;
                              
            *pCh = *pBegin;
                              
            *pBegin = temp;

                              Permutation(pStr, pBegin 
            + 1);

                              temp 
            = *pCh;
                              
            *pCh = *pBegin;
                              
            *pBegin = temp;
                        }
                  }
            }


            組合:
            對(duì)于組合,也是從頭掃描字符串的第一個(gè)元素,按照數(shù)學(xué)上的公式,對(duì)于第一個(gè)元素有兩種選擇,一是取該元素,然后再剩下來的 n - 1 個(gè)元素中取 m - 1 個(gè);而是不去該元素,然后在 n - 1 個(gè)元素中取 m 個(gè)元素。
            C(m, n) = C(m - 1, n - 1) + C(m, n - 1)
            這兩種選擇都可以進(jìn)一步遞歸求解。
            代碼描述:

            void Combination(char* string)
            {
                
            if(string == NULL)
                    
            return;

                
            int length = strlen(string);
                vector
            <char> result;
                
            for(int i = 1; i <= length; ++ i)
                {
                    Combination(
            string, i, result);
                }
            }

            void Combination(char* stringint number, vector<char>& result)
            {
                
            if(number == 0)
                {
                    vector
            <char>::iterator iter = result.begin();
                    
            for(; iter < result.end(); ++ iter)
                        printf(
            "%c"*iter);
                    printf(
            "\n");
                    
            return;
                }
                
            if(*string == '\0')
                    
            return;

                result.push_back(
            *string);
                Combination(
            string + 1, number - 1, result);
                result.pop_back();
                Combination(
            string + 1, number, result);
            }


            參考:
            字符串的排列
            http://zhedahht.blog.163.com/blog/static/254111742007499363479/
            字符串的組合
            http://zhedahht.blog.163.com/blog/static/2541117420114172812217/

            posted on 2011-09-17 09:54 unixfy 閱讀(114) 評(píng)論(0)  編輯 收藏 引用

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


            亚洲精品乱码久久久久久久久久久久 | 99久久精品国产毛片| 久久人人爽人人爽人人片AV麻烦 | 亚洲精品白浆高清久久久久久| 久久久久久久综合综合狠狠| 国产亚洲精久久久久久无码AV| 久久天堂电影网| 久久综合九色综合97_久久久| 秋霞久久国产精品电影院| 久久久久久久综合日本亚洲| 久久精品嫩草影院| 一级做a爱片久久毛片| 久久久久亚洲AV无码去区首| 久久亚洲色一区二区三区| 要久久爱在线免费观看| 久久人妻无码中文字幕| 亚洲国产精品久久久天堂| 狠狠色丁香久久综合五月| 久久国产精品免费一区| 久久精品久久久久观看99水蜜桃| 日韩av无码久久精品免费| 热久久这里只有精品| 色狠狠久久综合网| 国产日产久久高清欧美一区| 国产综合精品久久亚洲| 久久精品一本到99热免费| 99久久er这里只有精品18| 久久久久久av无码免费看大片| 亚洲伊人久久综合中文成人网| 久久夜色精品国产欧美乱| 精品无码人妻久久久久久| 伊人久久综合精品无码AV专区| 99久久国产热无码精品免费| 亚洲精品成人久久久| 久久99精品国产99久久6男男| 最新久久免费视频| 国产精品成人99久久久久| 久久久久久午夜精品| 久久精品一本到99热免费| 亚洲国产精品一区二区三区久久| 国产一级做a爰片久久毛片|