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

生成排列的算法(POJ - 1256 和 POJ百練 - 1833)

題目1描述:
輸入:一個序列s,該序列里面可能會有同樣的字符,不一定有序
輸出:打亂輸入中的序列,可能產生的所有新的序列
題目2描述:
輸入:一個序列s,該序列里面可能會有同樣的字符,不一定有序 和 一個整數k
輸出:該序列往后計算第k個序列,所有序列是以字典序排序的

如果會有序搜索的童鞋自然而然能立刻做出來第一個題目,可是第二個題目在s較長的情況下,卻需要用模擬而不是搜索...
大家都知道STL里面有個泛函模版, prev_permutation和next_permutation,用法也很簡單,實現的就是題目2的功能...
但是算法最好得靠自己想出來,自己想出來的才是自己的,碰到新的問題才能產生思想的火花...

廢話少說,題目1的解法就是深搜,不過需要加上一個bool數組標記和一個函數確定不同字符之間的大小(有可能這個大小還不是Ascii碼就能決定的),
大致描述下搜索過程,比如輸入序列是12345,那么我搜索的過程大致是第一層按順序選取1-5,進入第二層的時候也是按順序選取1-5,
以此類推,但是每一層里面都只能選前面的層次沒有選過的數,而且因為有重復字符,算法還必須保證每一層里面按順序選取的字符必須是升序的,
熟悉順序搜索和回溯的同學,很自然就會產生這樣的想法...
POJ - 1256的代碼如下:
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <stdlib.h>
#include <algorithm>
#define MAX (13 + 10)
using namespace std;
bool bUsed[MAX];
char szAns[MAX];
char szInput[MAX];
bool CmpChar(char chOne, char chTwo)
{
    if (abs(chOne - chTwo) != 'a' - 'A')
    {
        return tolower(chOne) - tolower(chTwo) < 0;
    }
    return chOne - chTwo < 0;
}
bool Greater(char chOne, char chTwo)
{
    if (abs(chOne - chTwo) != 'a' - 'A')
    {
        return tolower(chOne) - tolower(chTwo) > 0;
    }
    return chOne - chTwo > 0;
}
void Gen(int nDepth, int nLen)
{
    if (nDepth == nLen)
    {
        szAns[nLen] = '\0';
        printf("%s\n", szAns);
        return;
    }
    
    char chLast = '\0';
    for (int i = 0; i < nLen; ++i)
    {
        if (!bUsed[i] && Greater(szInput[i], chLast))
        {
            bUsed[i] = true;
            szAns[nDepth] = szInput[i];
            Gen(nDepth + 1, nLen);
            bUsed[i] = false;
            chLast = szInput[i];
        }
    }
}
int main()
{
    int nCases;
    
    scanf("%d", &nCases);
    while (nCases--)
    {
        scanf("%s", szInput);
        int nLen = strlen(szInput);
        sort(szInput, szInput + nLen, CmpChar);
        Gen(0, nLen);
    }
    
    return 0;
}
題目2的解法是模擬,功能類似與STL的那2個泛型模版函數,算法的大致過程是想辦法從當前序列進入下一個剛好比其大或者剛好比其小的序列...很自然我們想到要把序列后面大的字符交和前面小的字符交換就會使序列變大,為了使其剛好變大,可以把交換后的字符從交換位置起至最后都排序一下,現在的問題是我們如何選取2個字符交換...正確的想法是,我們從最后面開始往前面看,尋找一個最長的遞增序列,找到之后,我們只需要選取遞增序列前面的那個字符chBefore和遞增序列里面的一個最小的比chBefore大的字符交換即可...交換之后,將新的遞增序列排序一下即可...
為什么這樣做了,因為從后往前看的遞增序列,是不能交換2個字符讓當前序列變大的,所以必須選取最長遞增序列前面的那個字符交換...

POJ百練 - 1833 的代碼如下:
#include <stdio.h>
#include <string.h>
#include <algorithm>
#define MAX (1024 + 10)
using namespace std;
int nInput[MAX];
void GetNext(int* nInput, int nLen)
{
    int i = nLen - 2;
    while (i >= 0)
    {
        if (nInput[i] >= nInput[i + 1])
        {
            --i;
        }
        else
        {
            int k = i + 1;
            for (int j = nLen - 1; j > i; --j)
            {
                if (nInput[j] > nInput[i] && nInput[j] < nInput[k])
                {
                    k = j;
                }
            }
            swap(nInput[i], nInput[k]);
            sort(nInput + i + 1, nInput + nLen);
            return;
        }
    }
    
    sort(nInput, nInput + nLen);
}
int main()
{
    int nCases;
    scanf("%d", &nCases);
    while (nCases--)
    {
        int nLen;
        int nK;
        scanf("%d%d", &nLen, &nK);
        for (int i = 0; i < nLen; ++i)
        {
            scanf("%d", &nInput[i]);
        }
        for (int i = 0; i < nK; ++i)
        {
            GetNext(nInput, nLen);
        }
        for (int i = 0; i < nLen; ++i)
        {
            printf("%d%s", nInput[i], i == nLen - 1 ? "\n" : " ");
        }
    }
    return 0;
}

posted on 2011-12-26 15:53 yx 閱讀(1527) 評論(0)  編輯 收藏 引用 所屬分類: 搜索模擬

<2011年11月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

導航

統計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學

網友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美一区二区三区四区夜夜大片 | 国产日韩一区二区三区在线播放 | 欧美视频在线不卡| 亚洲综合成人婷婷小说| 亚洲日本视频| 久久国产精品免费一区| 亚洲美女在线看| 亚洲美女尤物影院| 久久天堂成人| 亚洲婷婷综合久久一本伊一区| 一级日韩一区在线观看| 久久综合电影一区| 国产一区二区在线免费观看| 在线中文字幕一区| 欧美韩国日本综合| 亚洲视频一区二区在线观看| 久久只有精品| 亚洲国产高清一区| 美日韩精品免费| 麻豆精品一区二区av白丝在线| 国产精品自拍小视频| 久久久久成人网| 久久久精品久久久久| 激情国产一区| 欧美二区不卡| 欧美特黄一级大片| 久久久一二三| 农夫在线精品视频免费观看| 禁久久精品乱码| 欧美电影资源| 国产麻豆精品theporn| 一区二区在线观看av| 久久人人97超碰国产公开结果| 欧美激情精品久久久久久久变态 | 亚洲视频一二区| 日韩视频免费观看高清在线视频 | 亚洲欧美日韩在线综合| 美日韩在线观看| 欧美日韩黄视频| 久久综合婷婷| 国产一区av在线| 这里是久久伊人| 亚洲日本中文字幕| 久久久国产精品一区二区中文| 欧美在线中文字幕| 国产精品video| 一区二区高清在线| 日韩亚洲综合在线| 午夜久久tv| 日韩午夜电影av| 国产亚洲网站| 亚洲美女黄色片| 国产欧美精品日韩精品| 久久精品中文字幕一区| 久久精品日产第一区二区三区| 午夜精品免费视频| 日韩天天综合| 亚洲精品一区在线| 国产欧美精品在线观看| 夜夜夜久久久| 91久久久一线二线三线品牌| 噜噜噜91成人网| 模特精品裸拍一区| 一区二区三欧美| 欧美激情区在线播放| 亚洲曰本av电影| 亚洲精品之草原avav久久| 在线成人www免费观看视频| 亚洲国产精品成人综合| 影音先锋成人资源站| 久久天天狠狠| 亚洲精品久久久久久久久| 亚洲欧美久久| 久久久久久久成人| 久久影视三级福利片| 亚洲动漫精品| 欧美一区二区三区久久精品茉莉花| 国产欧美日韩三级| 欧美激情一区二区三区在线| 亚洲欧美网站| 欧美bbbxxxxx| 国产亚洲欧美日韩美女| 欧美日韩999| 亚洲伊人观看| 99精品久久久| 亚洲人成网站777色婷婷| 欧美一区亚洲二区| 亚洲一级一区| 在线视频一区观看| 亚洲精品四区| 亚洲国产一区二区三区a毛片| 国产精品v欧美精品v日本精品动漫 | 韩日午夜在线资源一区二区| 国产精品扒开腿爽爽爽视频| 国产精品va在线播放| 国产精品永久在线| 黄色亚洲大片免费在线观看| 永久久久久久| 日韩亚洲欧美综合| 亚洲小视频在线观看| 欧美在现视频| 亚洲国产黄色片| 亚洲图片欧美午夜| 久久久久久亚洲综合影院红桃| 久久精品国产在热久久 | 欧美一区二区免费| 久久久久久穴| 国产精品家教| 久久久久久久欧美精品| 欧美激情综合五月色丁香| 国产精品综合久久久| 亚洲欧洲日产国产网站| 午夜在线播放视频欧美| 欧美成人免费观看| 性色一区二区| 欧美日韩三级一区二区| 精品成人乱色一区二区| 亚洲午夜精品福利| 亚洲欧洲一区二区天堂久久| 久久久99精品免费观看不卡| 亚洲欧美亚洲| 一区二区日韩欧美| 欧美天天综合网| 亚洲一级片在线看| 免费精品99久久国产综合精品| 亚洲精品久久久蜜桃| 亚洲午夜精品久久久久久app| 国内外成人在线| 99国产一区二区三精品乱码| 一区在线播放| 中文久久乱码一区二区| 亚洲黄色在线视频| 久久精品99久久香蕉国产色戒| 在线一区视频| 欧美精品少妇一区二区三区| 久久偷窥视频| 国产一区二区三区免费观看| 一区二区三区色| 99综合视频| 欧美激情一区二区三级高清视频| 免费观看日韩| 影音先锋国产精品| 久久超碰97人人做人人爱| 欧美一级精品大片| 国产精品美女久久久免费| 亚洲天堂av在线免费| 亚洲午夜黄色| 国产欧美精品国产国产专区| 午夜久久久久| 久久在线视频| 亚洲韩国精品一区| 欧美国产欧美综合| 欧美二区在线| 亚洲综合丁香| 欧美一区二区精品| 国产一区二区中文| 久久免费国产精品1| 久久亚洲精品中文字幕冲田杏梨| 国产精品99免费看 | 蜜桃伊人久久| 男人的天堂亚洲| 亚洲国产成人精品久久久国产成人一区| 免费91麻豆精品国产自产在线观看| 国产精品视频xxxx| 一本久道综合久久精品| 久久综合国产精品台湾中文娱乐网| 欧美日韩一区二区三区在线观看免| 欧美成人首页| 国产综合激情| 午夜精品久久久久久| 亚洲午夜久久久久久尤物| 欧美刺激性大交免费视频| 亚洲图色在线| 久热这里只精品99re8久| 影音先锋另类| 欧美激情综合网| 欧美一级久久| 另类亚洲自拍| 亚洲黄色影院| 国产九九视频一区二区三区| 亚洲一区图片| 一区二区在线观看视频| 免费在线成人| 亚洲主播在线| 亚洲精品久久久久久下一站| 久久久久久久网| 午夜视频久久久久久| 99热在这里有精品免费| 在线不卡中文字幕播放| 老司机午夜精品视频在线观看| 亚洲另类在线一区| 嫩草伊人久久精品少妇av杨幂| …久久精品99久久香蕉国产| 欧美视频在线观看一区| 欧美一区二区三区另类 | 欧美激情国产日韩| 欧美在线高清视频| 久久av在线看| 一区二区三区国产在线| 国产精品magnet|