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

算法學社
記錄難忘的征途
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>
            久久九九99| 在线观看视频一区二区| 亚洲欧洲一区二区三区久久| 国产欧美一区二区色老头 | 亚洲美洲欧洲综合国产一区| 亚洲国产美女| 亚洲电影毛片| 亚洲麻豆视频| 国产精品99久久久久久www| 亚洲视频在线视频| 午夜一级在线看亚洲| 久久国产精品久久久久久| 久久人体大胆视频| 欧美连裤袜在线视频| 国产精品三级久久久久久电影| 国产噜噜噜噜噜久久久久久久久| 国产亚洲精品久久久| 亚洲高清不卡| 亚洲影院高清在线| 另类国产ts人妖高潮视频| 亚洲电影自拍| 亚洲一区二区三区欧美| 欧美在线观看一二区| 欧美电影免费观看大全| 国产精品家教| 亚洲国产精品成人va在线观看| 一本不卡影院| 久久男女视频| 日韩午夜精品视频| 久久亚洲一区| 国产模特精品视频久久久久 | 久久久久免费观看| 欧美日韩高清免费| 影音先锋亚洲电影| 欧美亚洲视频在线观看| 欧美激情在线| 狠狠狠色丁香婷婷综合久久五月 | 欧美一区=区| 亚洲第一在线综合网站| 欧美一区二区高清在线观看| 欧美国产1区2区| 尤物yw午夜国产精品视频明星| 亚洲午夜电影在线观看| 亚洲夫妻自拍| 久久久久国色av免费看影院| 国产精品va| 夜夜爽av福利精品导航 | 欧美一区永久视频免费观看| 欧美区亚洲区| 91久久精品国产91性色tv| 国产一区二区三区直播精品电影 | 亚洲网站啪啪| 欧美日韩激情网| 亚洲九九精品| 欧美/亚洲一区| 欧美在线免费观看视频| 国产麻豆视频精品| 欧美中文字幕精品| 亚洲欧美日韩国产中文| 国产精品久久久99| 亚洲午夜高清视频| 一区二区三区色| 国产精品久久网站| 亚洲你懂的在线视频| 在线综合亚洲欧美在线视频| 欧美亚韩一区| 亚洲欧美一区二区三区极速播放 | 亚洲国产高清在线| 欧美成人按摩| 欧美精品一区二区三区蜜桃| 亚洲免费观看高清完整版在线观看熊 | 美女脱光内衣内裤视频久久网站| 国产午夜精品一区二区三区欧美| 亚洲免费视频在线观看| 中文日韩欧美| 国产视频精品免费播放| 久久人人爽国产| 噜噜噜在线观看免费视频日韩| 亚洲人成人99网站| 日韩一级黄色大片| 国产一级精品aaaaa看| 欧美xxx成人| 欧美日韩国产综合视频在线| 亚洲欧美视频一区| 久久国产精品毛片| 日韩一二三在线视频播| 在线综合+亚洲+欧美中文字幕| 国产精品午夜电影| 理论片一区二区在线| 欧美精品一卡二卡| 欧美在线地址| 欧美sm视频| 欧美一区二区黄色| 免费视频亚洲| 亚洲女ⅴideoshd黑人| 久久人人97超碰国产公开结果 | 亚洲电影av| 欧美成人精品一区二区| 亚洲一品av免费观看| 欧美一区在线视频| 99热免费精品| 久久精品人人做人人爽| aa亚洲婷婷| 久久国产加勒比精品无码| 99re成人精品视频| 欧美综合国产| 亚洲欧美福利一区二区| 美女诱惑一区| 久久精品国产亚洲a| 欧美巨乳在线观看| 美女视频黄免费的久久| 国产精品视屏| 亚洲经典自拍| 一区二区亚洲精品国产| 亚洲午夜免费福利视频| 亚洲黄色成人久久久| 亚洲女优在线| 亚洲私人影院| 欧美高清在线精品一区| 久久米奇亚洲| 国产精品永久入口久久久| 亚洲人精品午夜| 亚洲东热激情| 久久精品国产一区二区三区| 欧美在线啊v一区| 国产美女精品免费电影| 一区二区三区四区五区精品视频| 亚洲国产精品va在看黑人| 久久久久久久久蜜桃| 久久精品午夜| 国模私拍视频一区| 亚洲欧美日本在线| 欧美一区二区精品在线| 国产精品久久久久久久久久免费 | 免费成人av在线看| 国产欧美日韩综合一区在线观看 | 久久激情婷婷| 久久精品成人一区二区三区 | 国产精品一区二区三区久久| 99精品热6080yy久久 | 欧美电影在线观看完整版| 国语自产在线不卡| 久久久xxx| 免费视频一区二区三区在线观看| 国产一区视频在线观看免费| 午夜激情综合网| 久久深夜福利免费观看| 在线观看欧美| 欧美精品在线视频观看| 亚洲免费黄色| 国产精品久久久久国产精品日日| 亚洲免费成人av电影| 亚洲一本大道在线| 国产精品伦子伦免费视频| 亚洲一区二区三区午夜| 欧美一区二区三区四区高清| 国产亚洲一二三区| 久久精品国产清高在天天线 | 欧美电影在线观看完整版| 亚洲精品永久免费| 欧美三级特黄| 亚洲综合大片69999| 久久久久国色av免费看影院| 亚洲福利国产| 欧美日韩专区| 欧美在线视频一区二区三区| 欧美二区在线播放| 亚洲一本大道在线| 永久免费精品影视网站| 欧美久久一区| 欧美一区二区国产| 亚洲国产欧洲综合997久久| 一区二区三区高清在线| 国产美女诱惑一区二区| 欧美不卡视频| 亚洲一二三区在线观看| 免费永久网站黄欧美| 一区二区毛片| 在线播放中文一区| 欧美四级伦理在线| 久久综合五月天婷婷伊人| 99在线精品视频在线观看| 久久久免费av| 亚洲午夜免费视频| 亚洲春色另类小说| 国产欧美日韩中文字幕在线| 欧美精品久久天天躁| 欧美在线免费观看| 亚洲一级在线| 亚洲精选中文字幕| 欧美va天堂在线| 久久久精品视频成人| 亚洲一本大道在线| 亚洲精品欧美激情| 在线观看不卡| 国产日韩一区二区三区在线| 欧美日韩1234| 欧美福利一区二区三区| 久久久亚洲综合| 午夜精品久久|