青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

勤能補拙,Expter

成都游戲Coder,記錄游戲開發過程的筆記和心得!

一個字典生成算法幾種解法:

        最近做一個東西正好需要生成字典的算法,類似一些密碼字典生成器(主要運用在暴力破解)。生成的密碼會根據密碼長度與字典集合的長度成指數關系。
       可以用一個函數來表示
        f( x , y  )  = x ^y ;           x表示我們要生產的密碼長度,y表示我們要生成的密碼字典字符集合。

      當時想到就有3個算法。
      
    1.循環
         關于循環,可以參考水仙花數的多層嵌套求解,主要算法如下:

 1/// Dict 為生成的密碼 , g_Dict為字典集合
 2for ( int i = 0 ; i < Len  ; i++ )
 3{
 4    Dict[0= g_Dict[i];
 5
 6    for ( int j = 0 ; j < Len ; j++)
 7    {
 8        Dict[1= g_Dict[j];
 9
10        for ( int k = 0 ; k < Len ; k++ )
11        {
12            Dict[2= g_Dict[k];
13
14            /*
15            *    幾位密碼就嵌套幾層循環
16            */

17
18        }

19    }

20}

       這種方式移植不好,而且代碼臃腫。
    2.遞歸
       做過字符串的全排列的都明白這個算法,這種也是基于這種方式:但是由于隨著字典集合或者密碼長度的增加,很容易會出現堆棧的內存溢出。
     

 1void solve(int len,int p , int s,int n)
 2{
 3    int i;    
 4    if( s == n )
 5    {    
 6        ///std::cout << Dict << std::endl;
 7        return ;

 8    }
    
 9    if(s>n||p>n)
10        return;    
11    for( i=p ; i < len ; i++ )    
12    {    
13        solve(len,i+1,s+1,n);    
14    }

15}


    3.BFS
       有了前2種方法的不錯,然后寫了一個非遞歸的算法
        主要借用橫向掃描的方式,借鑒一個數組來進行記錄當前應該生成的密碼。
       主要算法如下:
        

 1/*
 2*    生成字典的函數       
 3*     @parm  需要生成的長度          
 4*/

 5void    MakeDict( int Len )
 6{
 7    char    Dict[MaxDictLen+1];            // 生成的字典字符串
 8    int        Array[MaxDictLen];            // 記錄當前應該生成字典數組
 9
10    memset( Array , 0  , sizeof(Array) );
11
12    bool    bStop =  true;
13
14    int        i,j;
15    for ( ; bStop ; )                    // 是否生成完畢
16    {
17        for ( i = 0 ; i < Len ; i++ )
18        {
19            Dict[i] = g_Dict[Array[i]];
20        }

21        Dict[Len] = '\0';
22
23        std::cout << Dict << std::endl;
24
25        /// 字典數組坐標更新
26        for ( j = Len - 1  ;  j >= 0 ;  j -- )        
27        {
28            Array[j] ++ ;
29
30            if ( Array[j] != ((int)g_Dict.length()) )
31            
32                break;
33            }

34            else
35            {
36                Array [j] = 0;
37                if( j == 0 )            // 生成完畢
38                    bStop = false;    
39            }

40        }

41    }

42}

附上第三個生成算法源碼:
link

posted on 2009-11-08 00:56 expter 閱讀(3477) 評論(1)  編輯 收藏 引用 所屬分類: 其他學習筆記算法與數據結構

評論

# re: 一個字典生成算法幾種解法: 2014-05-11 22:28 張晶

memset是什么  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产亚洲精品高潮| 亚洲一区高清| 亚洲视屏一区| 亚洲图色在线| 欧美亚洲系列| 狂野欧美性猛交xxxx巴西| 久久综合久久综合久久综合| 久久看片网站| 亚洲精品视频二区| 亚洲欧美影音先锋| 久久综合久久美利坚合众国| 欧美丰满高潮xxxx喷水动漫| 欧美午夜在线一二页| 国产色综合网| 日韩亚洲在线| 久久久久**毛片大全| 亚洲国产婷婷| 夜夜嗨av一区二区三区四区| 羞羞漫画18久久大片| 欧美a级一区| 国产精品视频你懂的| 亚洲成人在线观看视频| 亚洲小说春色综合另类电影| 久久免费午夜影院| 日韩一级网站| 欧美成人免费在线视频| 国产日韩精品电影| 一区二区三区国产在线观看| 久久美女性网| 亚洲最新色图| 欧美 亚欧 日韩视频在线| 国产精品区一区| 国产精品区免费视频| 亚洲成人影音| 欧美亚洲午夜视频在线观看| 亚洲精品你懂的| 亚洲欧美精品| 欧美日韩国产一中文字不卡| 激情自拍一区| 欧美在线综合| 亚洲一区二区三区高清| 欧美精品福利视频| 亚洲国产一区二区视频| 久久综合婷婷| 欧美在线一级va免费观看| 国产精品每日更新在线播放网址| 亚洲青色在线| 亚洲第一福利社区| 久久久久成人网| 国产亚洲激情| 久久国产精品99久久久久久老狼| 一本色道久久综合精品竹菊 | 欧美1区免费| 国产一区欧美日韩| 久久久久国产一区二区三区四区| 亚洲视频观看| 国产精品爽爽ⅴa在线观看| 中文精品视频| 亚洲精品在线二区| 欧美/亚洲一区| 日韩视频一区二区| 亚洲精品在线三区| 欧美日韩国产精品| 亚洲夜间福利| 亚洲欧美国产精品va在线观看| 国产精品国产福利国产秒拍 | 狠狠色狠狠色综合日日91app| 欧美一区不卡| 久久激情视频久久| 亚洲国产婷婷| 亚洲精品免费观看| 欧美视频中文字幕| 香蕉久久夜色| 久久狠狠亚洲综合| 亚洲第一页中文字幕| 欧美激情视频免费观看| 欧美人成在线视频| 午夜精品久久久久久久| 亚洲免费婷婷| 在线欧美电影| 亚洲精品日韩激情在线电影 | 国产精品久久久久影院亚瑟 | 国产精品亚洲激情| 欧美视频在线视频| 国语自产精品视频在线看| 久久中文久久字幕| 欧美电影在线播放| 亚洲一区一卡| 久久经典综合| 一区二区欧美在线| 欧美在线黄色| 亚洲少妇自拍| 久久久久国产精品麻豆ai换脸 | 久久久久久久久久久成人| 久久另类ts人妖一区二区| 日韩一级不卡| 欧美一站二站| 中文在线不卡| 老司机午夜精品视频| 亚洲欧美激情在线视频| 久久九九全国免费精品观看| 一本色道久久综合亚洲91| 欧美一区1区三区3区公司| 99精品视频免费观看| 久久国产黑丝| 午夜精品久久久久久久99樱桃 | 国产亚洲一区在线| 亚洲精品乱码久久久久久久久| 国产一区二区三区四区| 亚洲美女精品一区| 亚洲高清久久网| 欧美一区二区三区在线视频| 亚洲最黄网站| 免费不卡在线视频| 久久久精品国产免大香伊| 欧美色偷偷大香| 亚洲高清在线观看| 韩日欧美一区| 性欧美超级视频| 亚洲欧美另类综合偷拍| 欧美精品一区二区在线观看 | 亚洲人成人99网站| 一区视频在线播放| 性欧美暴力猛交69hd| 亚洲欧美亚洲| 欧美日韩国产综合视频在线| 免费看精品久久片| 国产一区二区高清不卡| 亚洲自拍三区| 亚洲欧美综合一区| 欧美午夜精彩| 亚洲午夜电影在线观看| 亚洲图片欧美一区| 欧美日韩小视频| 一本色道久久综合亚洲精品小说 | 欧美视频导航| 亚洲精品精选| 一区二区久久久久久| 欧美久久视频| 99国内精品| 亚洲欧美在线看| 亚洲素人一区二区| 欧美一区二区免费| 久久久久久一区二区| 国产亚洲午夜| 久久久噜噜噜久久中文字免| 久久伊伊香蕉| 亚洲国产精品小视频| 久久野战av| 91久久国产自产拍夜夜嗨| 日韩视频专区| 欧美视频在线不卡| 亚洲免费中文字幕| 久久夜色精品| 亚洲毛片av| 亚洲欧洲综合另类| 夜夜爽夜夜爽精品视频| 国产精品日韩| 欧美影院一区| 亚洲国产精品专区久久| 一本色道久久99精品综合| 国产精品日韩欧美| 久久se精品一区精品二区| 亚洲第一黄色网| 亚洲在线视频免费观看| 国产日韩欧美成人| 免费国产一区二区| 亚洲一区二区三区四区视频| 久久视频这里只有精品| 亚洲狼人综合| 国产一区二区日韩| 欧美激情视频网站| 亚洲欧洲av一区二区三区久久| 浪潮色综合久久天堂| 亚洲精品一区二区三区不| 欧美亚洲成人网| 久久综合久久久久88| 亚洲天堂久久| 欧美激情一区二区三区在线| 亚洲综合成人在线| 亚洲国产欧美一区二区三区久久 | 久久久久久9| 一本色道久久| 黄色在线一区| 国产精品高潮视频| 女主播福利一区| 久久国产欧美精品| 亚洲一区二区久久| 亚洲日本电影在线| 女女同性精品视频| 欧美在线影院| 亚洲一区免费| 夜夜躁日日躁狠狠久久88av| 一区二区在线视频| 国内揄拍国内精品久久| 国产精品久久网站| 国产精品成人一区二区网站软件| 美女爽到呻吟久久久久| 欧美一区日本一区韩国一区| av成人毛片|