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

posts - 33,  comments - 33,  trackbacks - 0
數(shù)獨問題
采用跳舞鏈方法會得到比較快的速度
用跳舞鏈解決的方法主要是將問題的模型轉(zhuǎn)換成01覆蓋模型,然后模板之
首先要了解它的限制條件:
(1) 每一格只能填一個數(shù)字
(2) 每一列的數(shù)字是不同的
(3) 每一行的數(shù)字是不同的
(4) 每一個九宮格的數(shù)字是不同的

那么我們可以構(gòu)造出一組狀態(tài):
行狀態(tài)(i,j,k):表示第i行第j列填第k個數(shù)
列狀態(tài)(i,j,k):表示第k個限制的子狀態(tài)為(i,j),子狀態(tài)根據(jù)限制而定
所以對于N層數(shù)獨來說,行有N*N*N,列有4*N*N

然后對于給出的數(shù)獨,如果改格子沒有數(shù)字就枚舉每個可能出現(xiàn)的數(shù)字插入,有數(shù)字就插入現(xiàn)成的,然后用跳舞鏈一下,就出結(jié)果了
代碼:
  1#include <stdio.h>
  2#include <string.h>
  3
  4const int N = 9;
  5
  6const int MAX_WIDTH = 4*N*N+10;
  7const int MAX_HEIGHT =N*N*N+10 ;
  8
  9struct DancingLinkNode
 10{
 11    int row;
 12    int col;
 13    DancingLinkNode* pR,*pL,*pU,*pD;
 14}
;
 15DancingLinkNode memPool[MAX_WIDTH*MAX_HEIGHT];
 16
 17class DancingLink
 18{
 19private:
 20    DancingLinkNode head;
 21    DancingLinkNode rows[MAX_HEIGHT];
 22    DancingLinkNode columns[MAX_WIDTH];
 23    int size[MAX_WIDTH];
 24    int nodeUseNum;//use to the memory pool
 25public:
 26    int len;
 27    int ans[MAX_HEIGHT];
 28    DancingLink()
 29    {
 30    }

 31    void init(int _r,int _c)
 32    {
 33        nodeUseNum = 0;
 34        head.row = _r;
 35        head.col = _c;
 36        head.pD = head.pL = head.pR = head.pU = &head;
 37
 38        for(int i = 0; i < _c; ++i)
 39        {
 40            columns[i].row = _r;
 41            columns[i].col = i;
 42            columns[i].pL = &head;
 43            columns[i].pR = head.pR;
 44            columns[i].pL->pR = &columns[i];
 45            columns[i].pR->pL = &columns[i];
 46            columns[i].pU = columns[i].pD = &columns[i];
 47            size[i] = 0;
 48        }

 49
 50        for(int i = _r - 1; i >= 0--i)
 51        {
 52            rows[i].col = _c;
 53            rows[i].row = i;
 54            rows[i].pU = &head;
 55            rows[i].pD = head.pD;
 56            rows[i].pU->pD = &rows[i];
 57            rows[i].pD->pU = &rows[i];
 58            rows[i].pL = rows[i].pR = &rows[i];
 59        }

 60        memset(ans,0,sizeof(ans));
 61        len = 0;
 62    }

 63
 64    void addNode(int _r,int _c)
 65    {
 66        DancingLinkNode* newNode = &memPool[nodeUseNum++];
 67        newNode->col = _c;
 68        newNode->row = _r;
 69        
 70        newNode->pR = &rows[_r];
 71        newNode->pL = rows[_r].pL;
 72        newNode->pL->pR = newNode;
 73        newNode->pR->pL = newNode;
 74
 75        newNode->pD = &columns[_c];
 76        newNode->pU = columns[_c].pU;
 77        newNode->pU->pD = newNode;
 78        newNode->pD->pU = newNode;
 79
 80        ++size[_c];
 81
 82    }

 83    void removeByLR(DancingLinkNode* _node)
 84    {
 85        _node->pL->pR = _node->pR;
 86        _node->pR->pL = _node->pL;
 87    }

 88    void removeByUD(DancingLinkNode* _node)
 89    {
 90        _node->pD->pU = _node->pU;
 91        _node->pU->pD = _node->pD;
 92    }

 93    
 94    void resumeByLR(DancingLinkNode* _node)
 95    {
 96        _node->pL->pR = _node;
 97        _node->pR->pL = _node;
 98    }

 99
100    void resumeByUD(DancingLinkNode* _node)
101    {
102        _node->pD->pU = _node;
103        _node->pU->pD = _node;
104    }

105
106    void cover(int _c)
107    {
108        if(_c >= 0 && _c < head.col)
109        {
110            removeByLR(&columns[_c]);    
111            for(DancingLinkNode* pCol = columns[_c].pD; pCol != &columns[_c]; pCol = pCol->pD)
112            {
113                if(pCol->col == head.col)
114                {
115                    continue;
116                }

117                for(DancingLinkNode* pRow = pCol->pR; pRow != pCol; pRow = pRow->pR)
118                {
119                    if(pRow->col == head.col)
120                    {
121                        continue;
122                    }

123                    --size[pRow->col];
124                    removeByUD(pRow);
125                }

126                removeByLR(pCol);
127            }

128        }

129    }

130
131    void resume(int _c)
132    {
133        if(_c >= 0 && _c < head.col)
134        {
135            for(DancingLinkNode* pCol = columns[_c].pU; pCol != &columns[_c]; pCol = pCol->pU)
136            {
137                if(pCol->col == head.col)
138                {
139                    continue;
140                }

141                resumeByLR(pCol);
142                for(DancingLinkNode* pRow = pCol->pL; pRow != pCol; pRow = pRow->pL)
143                {
144                    if(pRow->col == head.col)
145                    {
146                        continue;
147                    }

148                    ++size[pRow->col];
149                    resumeByUD(pRow);
150                }

151            }

152            resumeByLR(&columns[_c]);    
153        }

154    }

155
156
157    bool dfs(int _k)
158    {
159        if(head.pL == &head)
160        {
161            len = _k;
162            return true;
163        }

164        //選擇列(最小元素優(yōu)先)
165        int minV = (1 << 30);
166        int minVcol = -1;
167        for(DancingLinkNode* pNode = head.pL; pNode != &head; pNode = pNode->pL)
168        {
169            if(size[pNode->col] < minV)
170            {
171                minV = size[pNode->col];
172                minVcol = pNode->col;
173            }

174        }

175        cover(minVcol);
176        for(DancingLinkNode* pNode = columns[minVcol].pD; pNode != &columns[minVcol]; pNode = pNode->pD)
177        {
178            ans[_k] = pNode->row;
179            pNode->pL->pR = pNode;
180            for(DancingLinkNode* pNode2 = pNode->pR; pNode2 != pNode; pNode2 = pNode2->pR)
181            {
182                cover(pNode2->col);
183            }

184            if(dfs(_k+1))
185            {
186                return true;
187            }

188            pNode->pR->pL = pNode;
189            for(DancingLinkNode* pNode2 = pNode->pL; pNode2 != pNode; pNode2 = pNode2->pL)
190            {
191                resume(pNode2->col);
192            }

193            pNode->pL->pR = pNode->pR;
194        }

195        resume(minVcol);
196        return false;
197    }

198
199    void Print()
200    {
201        for(DancingLinkNode* pRow = head.pD; pRow != &head; pRow = pRow->pD)
202        {
203            if(pRow->row == head.row)
204            {
205                continue;
206            }

207            for(DancingLinkNode* pCol = pRow->pR; pCol != pRow; pCol = pCol->pR)
208            {
209                if(pCol->col == head.col)
210                    continue;
211                printf("(%d %d),",pCol->row,pCol->col);
212            }

213            printf("\n");
214        }

215    }

216}
;
217DancingLink DLX;
218char str[320];
219
220void Insert(int _r,int _c,int _k)
221{
222    int t = N*_r + _c;
223    int R = N*N*_k + t ;
224    int C = t ;
225    int B = ((int)(_r/3))*3 + _c/3;
226
227    DLX.addNode(R,C);
228    C = N*+ N*_r + _k;
229    DLX.addNode(R,C);
230    C = 2*N*+ N*_c + _k;
231    DLX.addNode(R,C);
232    C = 3*N*+ N*+ _k;
233    DLX.addNode(R,C);
234}

235
236void PrintAns()
237{
238    int reAns[N][N];
239    for(int i = 0; i < DLX.len; ++i)
240    {
241        int k = DLX.ans[i] / (N*N);
242        int r = (DLX.ans[i] - k*N*N)/N;
243        int c = DLX.ans[i] - k*N*- r*N;
244        reAns[r][c] = k+1;
245    }

246    for(int i = 0; i < N; ++i)
247    {
248        for(int j = 0; j < N; ++j)
249        {
250            printf("%d",reAns[i][j]);
251        }

252    }

253    printf("\n");
254}
 
255
256void Test()
257{
258    DLX.init(N*N*N,4*N*N);
259    for(int i = 0; i < N; ++i)
260    {
261        for(int j = 0; j < N; ++j)
262        {
263            if(str[i*N+j] == '.')
264            {
265                for(int k = 0; k < N; ++k)
266                {
267                    Insert(i,j,k);
268                }

269            }

270            else
271            {
272                Insert(i,j,str[i*N+j]-'1');
273            }

274        }

275    }

276    if(DLX.dfs(0))
277    {
278        PrintAns();
279    }

280}

281
282int main()
283{
284    while(gets(str))
285    {
286        if(strcmp(str,"end"== 0)
287            break;
288        Test();
289    }

290    return 0;
291}

同理,3076如法炮制
posted on 2012-03-12 19:37 bennycen 閱讀(2073) 評論(3)  編輯 收藏 引用 所屬分類: 算法題解
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国内自拍| 亚洲二区视频在线| 欧美在线网址| 欧美一级欧美一级在线播放| 亚洲亚洲精品在线观看| 在线一区二区视频| 亚洲制服少妇| 狼狼综合久久久久综合网 | 欧美日韩在线免费视频| 欧美日韩成人在线视频| 欧美午夜无遮挡| 国产亚洲欧洲一区高清在线观看| 好吊日精品视频| 亚洲精品日韩激情在线电影 | 国产午夜精品一区二区三区欧美| 国产一区激情| 一级日韩一区在线观看| 久久福利一区| 亚洲国产精品第一区二区| 亚洲精华国产欧美| 欧美一级理论性理论a| 欧美福利视频在线| 国产午夜精品在线| 中文久久精品| 亚洲国产va精品久久久不卡综合| 性8sex亚洲区入口| 欧美日韩欧美一区二区| 精品电影在线观看| 亚洲欧美日本日韩| 亚洲激情影视| 久久久蜜桃精品| 国产精品视频一| 亚洲精品日日夜夜| 六月丁香综合| 午夜精品视频| 国产精品www994| 亚洲美女中文字幕| 麻豆av一区二区三区久久| 亚洲午夜精品久久久久久浪潮| 久久久一区二区三区| 国产目拍亚洲精品99久久精品| 9l国产精品久久久久麻豆| 蜜臀a∨国产成人精品 | 国产精品扒开腿做爽爽爽视频| 亚洲第一久久影院| 久久精品国产99国产精品| 99精品热视频| 欧美日韩国产综合视频在线观看| 91久久久精品| 亚洲第一在线视频| 欧美韩国日本一区| 亚洲国产精品v| 裸体一区二区| 久久久夜精品| 红桃视频亚洲| 麻豆成人综合网| 久久嫩草精品久久久精品一| 好看的亚洲午夜视频在线| 久久se精品一区精品二区| 亚洲专区一区| 国产一区二区| 免费在线成人av| 免费成人激情视频| 亚洲精品综合| 一本一本久久a久久精品综合妖精| 欧美高清视频一区二区| 亚洲日本在线视频观看| 亚洲第一在线综合在线| 欧美成人精品在线| 亚洲最黄网站| 一区二区毛片| 国产伦精品一区二区三区视频黑人| 午夜免费久久久久| 欧美一区91| 一色屋精品视频在线观看网站| 性18欧美另类| 久久国产黑丝| 亚洲国产成人久久综合| 最新国产成人av网站网址麻豆 | 毛片一区二区三区| 久久久久亚洲综合| 亚洲巨乳在线| 亚洲视频在线观看| 99视频精品全国免费| 国产精品剧情在线亚洲| 久久嫩草精品久久久精品一| 玖玖玖国产精品| 一本大道av伊人久久综合| 亚洲一区二区黄色| 狠狠操狠狠色综合网| 亚洲精品日韩久久| 国模精品一区二区三区色天香| 最近中文字幕mv在线一区二区三区四区| 欧美日韩视频在线观看一区二区三区 | 欧美成人一品| 欧美视频免费| 欧美成人中文| 国产精品爱啪在线线免费观看| 久久婷婷综合激情| 欧美日韩国产在线一区| 久久影院亚洲| 国产精品卡一卡二| 亚洲黄色大片| 国产一级一区二区| 亚洲精品美女免费| 一区三区视频| 亚洲欧美激情诱惑| 久久全球大尺度高清视频| 欧美性猛交xxxx免费看久久久 | 99国产精品99久久久久久| 国内精品美女av在线播放| 99热这里只有成人精品国产| 亚洲欧洲日产国产网站| 欧美在线999| 午夜伦欧美伦电影理论片| 欧美高清影院| 免费视频一区二区三区在线观看| 国产精品久久久久秋霞鲁丝| 欧美激情一区二区三区高清视频 | 久久国产一区二区三区| 欧美色图一区二区三区| 亚洲国产美女精品久久久久∴| 黄色精品一区| 久久九九国产| 久久久久久久97| 国产啪精品视频| 亚洲小说欧美另类社区| 亚洲婷婷在线| 欧美亚韩一区| 日韩视频在线一区二区| 亚洲精品乱码久久久久久蜜桃麻豆| 久久精品亚洲热| 久久亚洲欧洲| 在线观看国产成人av片| 久久香蕉精品| 欧美肥婆bbw| 亚洲国产综合91精品麻豆| 久久久精品2019中文字幕神马| 久久久噜噜噜久久狠狠50岁| 国产亚洲毛片| 久久精品在线| 欧美成年人在线观看| 亚洲高清久久网| 你懂的一区二区| 亚洲国产日韩一区| 中文无字幕一区二区三区| 欧美亚洲成人精品| 亚洲欧美日韩成人高清在线一区| 欧美专区亚洲专区| 亚洲国产第一页| 欧美经典一区二区| 在线亚洲一区二区| 久久久久久999| 亚洲国产视频a| 欧美日韩性视频在线| 亚洲欧美另类国产| 欧美69wwwcom| 亚洲一区二区av电影| 国产亚洲成av人在线观看导航| 久久综合99re88久久爱| 亚洲免费大片| 久久久精品一区| 亚洲欧洲精品一区二区精品久久久| 美腿丝袜亚洲色图| 一本色道久久综合亚洲精品小说| 久久精品中文字幕免费mv| 亚洲激情图片小说视频| 国产精品vvv| 蜜臀久久99精品久久久久久9 | 亚洲第一福利社区| 亚洲男人第一网站| 国内精品99| 欧美精品一区二区在线观看| 亚洲一区视频| 欧美激情亚洲激情| 久久精品国产99精品国产亚洲性色 | 欧美日韩中文另类| 国产精品综合网站| 国产主播一区| 激情综合久久| 亚洲永久在线观看| 夜夜嗨av一区二区三区四区| 校园春色国产精品| 国产精品免费观看视频| 黑人巨大精品欧美一区二区| 亚洲精品日日夜夜| 亚洲视频二区| 欧美高清视频在线观看| 亚洲精品视频在线播放| 亚洲免费大片| 日韩一级在线观看| 欧美激情视频在线播放| 亚洲国产清纯| 欧美高清在线视频| 欧美视频在线观看视频极品| 亚洲第一黄色| 欧美大片在线观看| 91久久久精品| 亚洲欧美日韩在线播放| 亚洲电影专区|