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

算法學社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0

題目描述:

    N(N<100)個帶開關的燈泡排成一行,每個燈泡的開關可以轉換自己,左邊連續D個和右邊連續D個燈泡的開關狀態。現在給你每個燈泡的初始狀態{Ai},請問最少開關多少次能把所有的燈熄滅?

吐槽:

    1.上來就往DP的思路想是什么水平...
    2.本blog的第一個數學題目... mark~

思路分析:

    首先在最后的解中,顯然每個開關只能按一次。所以貌似可以狀壓DP?,但是由于開關可以控制后面的燈泡,所以100*2^30果斷GG...
    于是發現這個可以列出方程組,Xi表示開關i是否按下,Mij表示開關i是否可以控制燈泡j:
        (M00*X0) XOR (M10*X1) XOR ... XOR (M0n-1*Xn-1) = A0
        (M10*X0) XOR (M11*X1) XOR ... XOR (M1n-1*Xn-1) = A1
        .              .          ...      .           . .
        .              .          ...      .           . .
        .              .          ...      .           . .
        (Mj0*X0) XOR (Mj1*X1) XOR ... XOR (Mjn-1*Xn-1) = Aj
    
    這個異或方程組怎么解呢? 其實 A XOR B = (A + B) mod 2
    可以看成是同余方程組,那么經典的解法就是高斯-約當消元法了...
    其實算的時候還是用XOR操作方便一些...
    這個方程組的解有三種可能:
        1. 無解: 判斷消元后的系數矩陣是否存在 0 0 ... 0 1的情況,如果有輸出impossible,否則一定有解。
        2. 唯一解: 消去的過程中沒有自由變量,即對消去每一列的過程都有主元可以選擇,那么直接向前迭代求出唯一解~
        3. 無窮解: 存在自由變量,這個時候需要對自由變量進行枚舉,這個復雜度是指數級的,如果自由變量很少的話是ok的。那么如何估算自由變量呢?
                   矩陣的秩決定了自由變量的個數,不難發現這個矩陣是非常有特點的,從左到右畫了一個很粗的斜線 :P ,如果n滿足(n>2*D+1)的話,這個矩陣很明顯是滿秩的。
                   否則的話自由變量會在兩行完全相同的情況下出現,顯然這種情況下前n列都是1,這樣的行最多會出現D+1次。枚舉次數最多是2^(D+1),這樣就可以算了~
    
    2和3是可以放在一起寫的哦~
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cassert>
 4 using namespace std;
 5 #define re(i,n) for(int i =0; i< n; i++)
 6 #define re2(i,n) for(int i =0; i<= n; i++)
 7 const int M = 105;
 8 int gauss[M][M];
 9 int hash[M] , solution[M], P[M], val[M];
10 template <typename T> inline void chkmin(T &a, const T  b) { if(a > b) a = b;}
11 int main(){
12     int t;
13     cin >> t;
14     while(t --){
15         int n,d;
16         scanf("%d%d",&n,&d);
17         re(i,n) {
18             scanf("%d",&gauss[i][n]);
19         }
20         int N = 0;
21         re(i,n) {
22             re(j,n) gauss[i][j] = 0;
23             int l = max(0, i - d);
24             int r = min(n-1, i + d);
25             for(int j = l; j<= r; j++)
26                 gauss[i][j] = 1;
27         }
28         re(i,n) P[i] = -1 , hash[i] = 0;
29 //        re(i,n) {re2(j,n) cout << gauss[i][j] << " "; cout<<endl;} cout<<endl;
30         re(i,n) {
31             bool flag = 0;
32             re(j,n) if(!hash[j] && gauss[j][i]){
33                 P[i] = j;
34                 flag = hash[j] = 1;
35                 re(k,n) if(!hash[k] && gauss[k][i])
36                     for(int x = i; x <= n; x++)
37                         gauss[k][x] ^= gauss[j][x];
38                 break;
39             }
40             if(!flag) val[N++] = i;
41         }
42 //        re(i,n) {re2(j,n) cout << gauss[i][j] << " "; cout<<endl;} cout<<endl;
43         assert(N <=16);
44         bool s = 0; int mask = 1 << N;
45         re(i,n) {
46             bool flag = 0;
47             re(j,n) if(gauss[i][j]) flag = 1;
48             if(!flag && gauss[i][n]) { s = 1; break; }
49         }
50         if(s) { puts("impossible"); continue; }
51         int ans = M;
52         re(i, mask){
53             int sum =0;
54             re(j,N) solution[ val[j] ] = (i & (1 << j)) != 0;
55             for(int j =n-1 ; j >= 0; j--){
56                 if(P[j] == -1) continue;
57                 assert(gauss[P[j]][j]);
58                 solution[j] = gauss[P[j]][n];
59                 for(int k = n-1; k>j; k--)
60                     solution[j] ^= solution[k] & gauss[P[j]][k];
61             }
62             re(j,n) sum += solution[j]!=0;
63             chkmin(ans,sum);
64         }
65         cout<<ans<<endl;
66     }
67 }
68 
posted on 2012-04-27 18:26 西月弦 閱讀(621) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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国产精品久久久久| 久久免费黄色| 亚洲承认在线| 久久综合999| 麻豆91精品| 亚洲国产精品久久久久| 亚洲国产小视频在线观看| 欧美黄色一区| 亚洲一区二区综合| 久久精品99| 欧美日本韩国在线| 欧美+日本+国产+在线a∨观看| 欧美电影免费观看| 久久久久这里只有精品| 欧美激情视频在线免费观看 欧美视频免费一 | 亚洲一级片在线看| 亚洲精品一二三| 亚洲视频在线一区| 久久精品视频va| 鲁大师影院一区二区三区| 亚洲国产精品久久久久秋霞蜜臀| 日韩午夜激情电影| 欧美一区二区女人| 欧美视频在线观看 亚洲欧| 国产亚洲精品7777| 亚洲在线播放| 亚洲国产cao| 久久天堂成人| 国产综合欧美| 欧美有码在线观看视频| 日韩天堂在线视频| 欧美久久在线| 在线亚洲精品| 亚洲免费大片| 欧美日韩国产精品一卡| 亚洲看片免费| 亚洲人成免费| 欧美日韩亚洲一区三区 | 欧美在线3区| 国产精品中文字幕欧美| 午夜久久影院| 久久精品最新地址| 亚洲大片在线| 最新日韩中文字幕| 欧美日韩国产成人精品| 久久久久久穴| 国产精品亚洲综合天堂夜夜| 亚洲私拍自拍| 欧美一区二区在线播放| 国产一区视频在线观看免费| 久久精品一本久久99精品| 久久久久久久久蜜桃| 99精品国产99久久久久久福利| 在线视频你懂得一区二区三区| 国产乱码精品一区二区三区av| 久久国产精品一区二区| 欧美日韩福利在线观看| 久久性色av| 国产精品日韩在线| 亚洲福利在线看| 国产一区二区三区久久 | 亚洲手机在线| 久久综合狠狠综合久久综青草| 亚洲狼人精品一区二区三区| 午夜视频一区在线观看| 这里只有精品视频在线| 欧美电影免费| 亚洲美女av在线播放| 亚洲欧洲久久| 蜜臀va亚洲va欧美va天堂| 久久网站免费| 亚洲高清在线视频| 久久视频一区| 欧美国产日产韩国视频| 1024国产精品| 美女视频网站黄色亚洲| 亚洲国产成人精品久久久国产成人一区| 欧美激情精品| 亚洲精选大片| 欧美日韩国产成人在线观看| 亚洲美女中文字幕| 亚洲伊人观看| 国产精品亚洲网站| 久久国产99| 91久久在线播放| 亚洲欧美日韩一区二区| 国产日韩欧美一区二区| 亚洲高清不卡一区| 亚洲欧美另类在线观看| 亚洲第一在线视频| 欧美日本一区二区视频在线观看| 欧美激情1区2区| 亚洲小说欧美另类社区| 国产精品入口66mio| 久久午夜羞羞影院免费观看| 日韩视频在线一区二区| 久久免费高清| 欧美在线播放高清精品| 日韩视频免费观看| 尤物网精品视频| 国产精品系列在线| 欧美日韩视频一区二区三区| 久久久国产一区二区| 亚洲视频一二三| 亚洲精品国产欧美| 欧美3dxxxxhd| 久久久人成影片一区二区三区| 午夜在线精品偷拍| 亚洲在线观看免费| 亚洲免费人成在线视频观看| 一区二区高清| 99riav久久精品riav| 亚洲激情在线| 亚洲精品一区二区三区蜜桃久| 国内自拍一区| 亚洲大片av| 久久久久久欧美| 久久久久久久尹人综合网亚洲| 性做久久久久久久久| 久久疯狂做爰流白浆xx| 久久综合给合| 欧美人成在线| 国产精品亚洲片夜色在线| 国产日韩欧美综合精品| 狠狠色丁香久久综合频道| 国内视频精品| 一本大道久久精品懂色aⅴ| 亚洲欧美激情一区二区| 久久久伊人欧美| 亚洲美女精品久久| 久久精品欧美日韩精品| 欧美日韩精品综合| 一区在线播放视频| 亚洲欧美日韩国产中文| 欧美成人免费视频| 亚洲欧美韩国| 欧美激情视频给我| 精品白丝av| 久久精品国产77777蜜臀| 亚洲国产视频一区二区| 欧美专区亚洲专区| 国产欧美一区二区三区久久 | 亚洲精品久久| 欧美一区三区二区在线观看| 亚洲成色777777女色窝| 欧美资源在线观看| 国产视频一区在线| 亚洲欧美久久久| 亚洲一区二区四区| 国产精品乱码| 午夜国产精品视频| 亚洲一区二区免费看| 国产精品国产三级国产aⅴ浪潮| 日韩一区二区精品葵司在线| 欧美高清成人| 久久久久五月天| 欧美一区三区二区在线观看| 国产精品日韩高清| 久久精品国产亚洲一区二区三区| 亚洲视频大全| 亚洲高清久久| 亚洲免费成人av| 国产日韩综合| 亚洲国产欧美国产综合一区| 欧美精品一区二区在线播放| 一区二区三区视频在线观看| 在线亚洲精品| 在线观看成人小视频| 亚洲国产婷婷香蕉久久久久久99 | 国产精品欧美日韩久久| 亚洲男人的天堂在线| 久久一区二区三区国产精品| 亚洲精品欧美一区二区三区| 亚洲一区二区久久| 亚洲国产日韩欧美在线99| 一区二区毛片| 亚洲精品久久视频| 久久精品成人一区二区三区 | 激情欧美丁香| 在线亚洲一区观看| 91久久国产精品91久久性色| 亚洲美女免费视频| 久久精品一区四区| 国产精品欧美日韩| 亚洲免费黄色| 99国产精品视频免费观看| 欧美在线高清| 久久全球大尺度高清视频| 欧美日韩在线免费观看| 免费av成人在线| 亚洲第一综合天堂另类专| 久久亚洲精品一区二区| 免费在线观看一区二区| 亚洲第一黄色网| 噜噜噜躁狠狠躁狠狠精品视频| 国产欧美精品|