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

NOI2005 智慧珠游戲

Posted on 2011-07-20 23:07 Mato_No1 閱讀(1190) 評論(2)  編輯 收藏 引用 所屬分類: 搜索NOI
【原題見這里
很明顯的精確覆蓋的模型,12個零件,再加上它們經過旋轉、翻轉后的不同形狀,共60種,每種又可以放在不同的位置(只看最左上的那個珠子)一種零件的一種位置就是一行。列(限制)有兩種:每個格子只能放一個(55列),以及每個零件(注意是每個零件,不是每種零件)只能用一次(12列),共67列。預先放的那些零件可以看成預先選中的行。然后DLX精確覆蓋即可。

下面是DLX精確覆蓋的幾個易疵點:
(1)整個矩陣的行數和列數不能疵(比如本題是1644行,67列);
(2)注意init_d()、add_node(int, int)、delcol(int)、resucol(int)中的一些細節:
【1】init_d()中,是否把m寫成了n;
【2】add_node(int, int)中,是否寫了cols[c]++;
【3】delcol(int)和resucol(int)中,變量有木有疵(比如把i寫成j之類的),另外是否對cols進行了處理;
(3)如果有一些行預先被選中,注意在刪掉這些行的時候是否刪光,不要漏了行頭(rowh);
(4)注意區分行號、列號和結點下標,delcol(int x)和resucol(int x)中的參數x一定是列號,而記錄可行解的res數組里存放的一定是行號;
(5)結點的行、列號均從1開始(第0行、第0列有特殊意義);
(6)如果有多組數據,檢查在每組數據之前是否將所有數組初始化;

本題代碼:
#include <iostream>
#include 
<stdio.h>
using namespace std;
#define re(i, n) for (int i=0; i<n; i++)
#define re1(i, n) for (int i=1; i<=n; i++)
#define re3(i, l, r) for (int i=l; i<=r; i++)
#define set(i, j, x, y) PX[i][j] = x; PY[i][j] = y;
const int S = 10, n = 1644, m = 67, T = 60, INF = ~0U >> 2;;
const int LL[12= {046141519273139474852}, RR[12= {3513141826303846475159};
const char SSS[T + 1= "AAAABBCCCCCCCCDEEEEFFFFFFFFGGGGHHHHHHHHIIIIIIIIJKKKKLLLLLLLL";
struct dlnode {
    
int r, c, U, D, L, R;
} d[(n 
+ 1* (m + 1)];
int rowh[n + 1], cols[m + 1], nodes, PX[T][5], PY[T][5], len[T], No[S][S], pos[n + 1][3], _pos[T][S][S], res[n], res_len;
char a[S][S];
bool vst[12];
void init_d()
{
    re3(i, 
0, m) {d[i].U = d[i].D = i; d[i].L = i - 1; d[i].R = i + 1;} d[0].L = m; d[m].R = 0; nodes = m;
    re1(i, n) rowh[i] 
= -1;
    re1(i, m) cols[i] 
= 0;
}
void add_node(int r, int c)
{
    cols[c]
++; d[++nodes].r = r; d[nodes].c = c; d[nodes].U = d[c].U; d[nodes].D = c; d[c].U = nodes; d[d[nodes].U].D = nodes;
    
int rh = rowh[r]; if (rh == -1) d[nodes].L = d[nodes].R = rowh[r] = nodes; else {
        d[nodes].L 
= d[rh].L; d[nodes].R = rh; d[rh].L = nodes; d[d[nodes].L].R = nodes;
    }
}
void init()
{
    freopen(
"zhzyx.in""r", stdin);
    
char ch;
    re(i, S) {
        re(j, i
+1) a[i][j] = getchar();
        ch 
= getchar();
    }
    fclose(stdin);
}
void delLR(int x)
{
    d[d[x].L].R 
= d[x].R; d[d[x].R].L = d[x].L;
}
void resuLR(int x)
{
    d[d[x].L].R 
= d[d[x].R].L = x;
}
void delUD(int x)
{
    d[d[x].U].D 
= d[x].D; d[d[x].D].U = d[x].U;
}
void resuUD(int x)
{
    d[d[x].U].D 
= d[d[x].D].U = x;
}
void delcol(int x)
{
    delLR(x); 
for (int i=d[x].D; i != x; i=d[i].D) for (int j=d[i].R; j != i; j=d[j].R) {cols[d[j].c]--; delUD(j);}
}
void resucol(int x)
{
    
for (int i=d[x].U; i != x; i=d[i].U) for (int j=d[i].L; j != i; j=d[j].L) {resuUD(j); cols[d[j].c]++;} resuLR(x);
}
void prepare()
{
    init_d();
    len[
0= 3set(0000); set(0101); set(0210);
    len[
1= 3set(1000); set(1101); set(1211);
    len[
2= 3set(2000); set(2110); set(2211);
    len[
3= 3set(3000); set(3110); set(321-1);
    len[
4= 4set(4000); set(4101); set(4202); set(4303);
    len[
5= 4set(5000); set(5110); set(5220); set(5330);
    len[
6= 4set(6000); set(6101); set(6202); set(6310);
    len[
7= 4set(7000); set(7101); set(7202); set(7312);
    len[
8= 4set(8000); set(8110); set(8211); set(8312);
    len[
9= 4set(9000); set(9110); set(921-1); set(931-2);
    len[
10= 4set(10000); set(10101); set(10210); set(10320);
    len[
11= 4set(11000); set(11101); set(11211); set(11321);
    len[
12= 4set(12000); set(12110); set(12220); set(12321);
    len[
13= 4set(13000); set(13110); set(13220); set(1332-1);
    len[
14= 4set(14000); set(14101); set(14210); set(14311);
    len[
15= 5set(15000); set(15110); set(15220); set(15321); set(15422);
    len[
16= 5set(16000); set(16110); set(16220); set(1632-1); set(1642-2);
    len[
17= 5set(17000); set(17101); set(17202); set(17310); set(17420);
    len[
18= 5set(18000); set(18101); set(18202); set(18312); set(18422);
    len[
19= 5set(19000); set(19101); set(19202); set(19303); set(19411);
    len[
20= 5set(20000); set(20101); set(20202); set(20303); set(20412);
    len[
21= 5set(21000); set(2111-1); set(21210); set(21311); set(21412);
    len[
22= 5set(22000); set(2211-2); set(2221-1); set(22310); set(22411);
    len[
23= 5set(23000); set(23110); set(23211); set(23320); set(23430);
    len[
24= 5set(24000); set(24110); set(2421-1); set(24320); set(24430);
    len[
25= 5set(25000); set(25110); set(25220); set(25321); set(25430);
    len[
26= 5set(26000); set(26110); set(26220); set(2632-1); set(26430);
    len[
27= 5set(27000); set(27101); set(27202); set(27310); set(27412);
    len[
28= 5set(28000); set(28110); set(28211); set(28302); set(28412);
    len[
29= 5set(29000); set(29101); set(29210); set(29320); set(29421);
    len[
30= 5set(30000); set(30101); set(30211); set(30320); set(30421);
    len[
31= 5set(31000); set(31101); set(31202); set(31310); set(31411);
    len[
32= 5set(32000); set(32101); set(32202); set(32311); set(32412);
    len[
33= 5set(33000); set(33101); set(33210); set(33311); set(33412);
    len[
34= 5set(34000); set(34101); set(3421-1); set(34310); set(34411);
    len[
35= 5set(35000); set(35101); set(35210); set(35311); set(35420);
    len[
36= 5set(36000); set(36101); set(36210); set(36311); set(36421);
    len[
37= 5set(37000); set(37110); set(37211); set(37320); set(37421);
    len[
38= 5set(38000); set(3811-1); set(38210); set(3832-1); set(38420);
    len[
39= 5set(39000); set(39101); set(39202); set(39312); set(39413);
    len[
40= 5set(40000); set(40101); set(40202); set(4031-1); set(40410);
    len[
41= 5set(41000); set(41101); set(41211); set(41312); set(41413);
    len[
42= 5set(42000); set(42101); set(4221-2); set(4231-1); set(42410);
    len[
43= 5set(43000); set(43110); set(43220); set(43321); set(43431);
    len[
44= 5set(44000); set(44110); set(4422-1); set(44320); set(4443-1);
    len[
45= 5set(45000); set(45110); set(45211); set(45321); set(45431);
    len[
46= 5set(46000); set(4611-1); set(46210); set(4632-1); set(4643-1);
    len[
47= 5set(47000); set(4711-1); set(47210); set(47311); set(47420);
    len[
48= 5set(48000); set(48110); set(48211); set(48321); set(48422);
    len[
49= 5set(49000); set(4911-1); set(49210); set(4932-2); set(4942-1);
    len[
50= 5set(50000); set(50101); set(50211); set(50312); set(50422);
    len[
51= 5set(51000); set(51101); set(5121-1); set(51310); set(5142-1);
    len[
52= 5set(52000); set(52101); set(52202); set(52303); set(52410);
    len[
53= 5set(53000); set(53101); set(53202); set(53303); set(53413);
    len[
54= 5set(54000); set(5411-3); set(5421-2); set(5431-1); set(54410);
    len[
55= 5set(55000); set(55110); set(55211); set(55312); set(55413);
    len[
56= 5set(56000); set(56101); set(56210); set(56320); set(56430);
    len[
57= 5set(57000); set(57101); set(57211); set(57321); set(57431);
    len[
58= 5set(58000); set(58110); set(58220); set(58330); set(58431);
    len[
59= 5set(59000); set(59110); set(59220); set(5933-1); set(59430);
    
int No0 = 0, x0, y0, z; re(i, S) re(j, i+1) No[i][j] = ++No0;
    
bool ff;
    No0 
= 0; re(i, T) re(x, S) re(y, x+1) {
        ff 
= 1; re(j, len[i]) {
            x0 
= x + PX[i][j]; y0 = y + PY[i][j];
            
if (x0 < 0 || x0 >= S || y0 < 0 || y0 >= S || x0 < y0) {ff = 0break;}
        }
        
if (ff) {
            No0
++; pos[No0][0= i; pos[No0][1= x; pos[No0][2= y; _pos[i][x][y] = No0;
            re(j, len[i]) {x0 
= x + PX[i][j]; y0 = y + PY[i][j]; add_node(No0, No[x0][y0]);} add_node(No0, 55 + SSS[i] - 64);
        }
    }
    re(i, 
12) vst[i] = 0;
    
int _x, rh;
    re(x, S) re(y, x
+1if (a[x][y] != '.') {
        z 
= a[x][y] - 65;
        
if (!vst[z]) {
            vst[z] 
= 1;
            re3(i, LL[z], RR[z]) {
                ff 
= 1; re(j, len[i]) {
                    x0 
= x + PX[i][j]; y0 = y + PY[i][j];
                    
if (x0 < 0 || x0 >= S || y0 < 0 || y0 >= S || x0 < y0 || a[x0][y0] != a[x][y]) {ff = 0break;}
                }
                
if (ff) {
                    _x 
= _pos[i][x][y]; rh = rowh[_x]; delcol(d[rh].c);
                    
for (int j=d[rh].R; j != rh; j=d[j].R) delcol(d[j].c);
                    
break;
                }
            }
        }
    }
}
bool dfs(int dep)
{
    
if (!d[0].R) {res_len = dep; return 1;}
    
int mins = INF, c0; for (int i=d[0].R; i; i=d[i].R) if (!cols[i]) return 0else if (cols[i] < mins) {mins = cols[i]; c0 = i;}
    delcol(c0);
    
for (int i=d[c0].D; i != c0; i=d[i].D) {
        
for (int j=d[i].R; j != i; j=d[j].R) {delcol(d[j].c);}
        res[dep] 
= d[i].r; if (dfs(dep + 1)) return 1;
        
for (int j=d[i].L; j != i; j=d[j].L) resucol(d[j].c);
    }
    resucol(c0);
    
return 0;
}
void solve()
{
    
int x, y, z;
    
if (dfs(0)) {
        re(i, res_len) {
            z 
= pos[res[i]][0]; x = pos[res[i]][1]; y = pos[res[i]][2];
            re(j, len[z]) a[x 
+ PX[z][j]][y + PY[z][j]] = SSS[z];
        }
    } 
else res_len = -1;
}
void pri()
{
    freopen(
"zhzyx.out""w", stdout);
    
if (res_len == -1) puts("No solution"); else re(i, S) {re(j, i+1) putchar(a[i][j]); puts("");}
    fclose(stdout);
}
int main()
{
    init();
    prepare();
    solve();
    pri();
    
return 0;
}

Feedback

# re: NOI2005 智慧珠游戲  回復  更多評論   

2014-09-28 17:01 by
把代碼放在vs2013上跑,一直在prepare里循環...

# re: NOI2005 智慧珠游戲  回復  更多評論   

2015-01-07 18:40 by sluqy671
add_node(No0, 55 + SSS[i] - 64);
請問這句話有什么作用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 麻豆精品网站| 欧美日韩一区二区视频在线观看| 欧美日韩一区二区三区四区五区| 国产精品亚洲综合久久| 国产主播在线一区| 日韩天堂在线观看| 午夜精品久久久久久久99水蜜桃| 久久久精品tv| 亚洲黄色成人久久久| 亚洲一区三区视频在线观看 | 欧美大片免费观看| 亚洲国产一成人久久精品| 亚洲色诱最新| 美女视频黄免费的久久| 欧美日韩在线一区二区三区| 加勒比av一区二区| 国产精品99久久久久久白浆小说| 欧美亚洲在线播放| 亚洲福利在线观看| 亚洲综合社区| 欧美成人一区在线| 国模一区二区三区| 在线视频一区观看| 欧美成在线观看| 亚洲在线视频网站| 欧美福利影院| 国产综合色在线| 亚洲视频www| 免费观看一区| 午夜精品999| 欧美国内亚洲| 激情另类综合| 欧美制服第一页| 亚洲另类自拍| 麻豆精品91| 国产一区二区三区四区五区美女| 一本大道久久a久久精二百| 久久久午夜精品| 亚洲视频在线观看网站| 欧美激情一二区| 亚洲黄色一区二区三区| 久久午夜羞羞影院免费观看| 亚洲欧美中文字幕| 国产精品日韩在线观看| 亚洲性夜色噜噜噜7777| 亚洲国产综合在线| 欧美高清视频一区二区| 亚洲第一在线视频| 免费日韩av片| 老牛嫩草一区二区三区日本| 久久电影一区| 国产精品美女久久久久av超清 | 久久精品在线观看| 久久免费黄色| 99热在这里有精品免费| 久久一综合视频| 国产亚洲日本欧美韩国| 性欧美videos另类喷潮| 欧美怡红院视频| 一区二区免费在线视频| 欧美性jizz18性欧美| 亚洲视频香蕉人妖| 一区二区三区四区五区精品视频| 欧美日本一区| 亚洲一区久久| 亚洲欧美激情视频在线观看一区二区三区 | 久久在线免费视频| 在线免费观看日本一区| 免费日韩视频| 欧美国产先锋| 亚洲免费一在线| 欧美亚洲免费电影| 亚洲高清自拍| 99视频精品在线| 国产日韩综合一区二区性色av| 久久久久久一区| 欧美大片第1页| 亚洲欧美影院| 久久深夜福利| 亚洲免费人成在线视频观看| 欧美一级艳片视频免费观看| 影音先锋一区| 日韩视频―中文字幕| 国产一区二区日韩| 亚洲三级免费观看| 国产精品xxxxx| 免费久久久一本精品久久区| 欧美日韩一区二区欧美激情 | 久久全国免费视频| 一区二区三区四区五区在线| 欧美一区成人| 美女精品在线| 在线视频欧美日韩| 久久国产精品久久久久久| 亚洲精品乱码久久久久久黑人| 亚洲午夜精品一区二区| 亚洲国产欧美久久| 午夜精品久久久久久久久久久久久| 亚洲第一福利视频| 亚洲欧美中文日韩在线| 一本久久精品一区二区| 久久婷婷综合激情| 久久高清国产| 欧美色综合天天久久综合精品| 免费看的黄色欧美网站| 国产欧美一区二区三区在线老狼 | 国产精品久久久久久久app| 欧美成人dvd在线视频| 国产伦一区二区三区色一情| 亚洲人成在线免费观看| 亚洲成人在线网| 欧美影院在线播放| 亚洲一卡久久| 欧美日韩午夜在线| 亚洲日本成人在线观看| 亚洲人成网站色ww在线| 久久人人爽人人爽| 另类激情亚洲| 精品成人在线视频| 久久久精品久久久久| 久久精品国产亚洲一区二区| 国产精品久久久久久久久果冻传媒| 亚洲日韩欧美一区二区在线| 亚洲欧洲日本专区| 欧美成人精品三级在线观看 | 久久国产66| 国产精品美女在线观看| 一区二区三区精品| 亚洲欧美综合国产精品一区| 国产精品九色蝌蚪自拍| 亚洲一级电影| 午夜在线精品偷拍| 国产欧美在线观看一区| 午夜宅男欧美| 久久综合国产精品| 亚洲国产精品第一区二区| 久久全国免费视频| 亚洲福利国产精品| 日韩视频专区| 欧美日韩p片| 亚洲图片欧洲图片日韩av| 香蕉成人伊视频在线观看| 国产亚洲成av人片在线观看桃| 久久超碰97中文字幕| 久久一区二区三区av| 91久久中文| 国产精品久久久久久久久搜平片| 亚洲欧美中文日韩在线| 久久亚洲视频| 亚洲黄色av一区| 欧美午夜宅男影院| 欧美在线影院在线视频| 亚洲第一综合天堂另类专| 亚洲小视频在线| 欧美日韩国产一区二区| 亚洲欧美国产精品va在线观看| 国产精品视频专区| 久久先锋影音av| 亚洲精品一级| 久久精品国产在热久久| 亚洲国产精品小视频| 欧美性jizz18性欧美| 久久精品国产第一区二区三区| 亚洲黄色精品| 欧美伊人久久久久久久久影院| 亚洲国内精品| 国产精品综合不卡av| 欧美 日韩 国产精品免费观看| 亚洲午夜精品国产| 欧美国产日韩一区| 欧美伊人影院| 亚洲天天影视| 最新国产成人av网站网址麻豆| 国产精品久久久久久久久动漫| 两个人的视频www国产精品| 亚洲一区二区欧美日韩| 亚洲二区免费| 久久久一区二区三区| 亚洲一区二区三区欧美| 亚洲黄一区二区| 国产自产v一区二区三区c| 欧美日韩在线免费| 欧美11—12娇小xxxx| 久久精品二区| 亚洲欧美一区二区激情| 日韩一级免费观看| 亚洲国产国产亚洲一二三| 久久精品男女| 午夜亚洲性色视频| 亚洲少妇中出一区| 日韩一区二区电影网| 在线成人性视频|