BFS

今天詳細(xì)看了一下BFS
算法和之前學(xué)習(xí)的……emmmmmm可能開始不夠吧
先看一下藍(lán)橋杯一道全球變暖的題……恨不得練10000道讓我信手捏來一個(gè)dfs
第一遍一直提醒自己遞歸庙楚,然而……
思路就是最開始統(tǒng)計(jì)一下多少個(gè)島嶼
然后淹沒之后統(tǒng)計(jì)島嶼相減
然而第一遍每次都是從頭到尾遍歷层亿,相當(dāng)于樹的層序遍歷吧,復(fù)雜度極高,運(yùn)行時(shí)間也很長

#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <vector>
using namespace std;
int n;
char MAP[1005][1005];

struct plain{
    bool tag;
    bool drown;
    int k;
};
plain MAP2[1005][1005];

int dir[4][2]={-1,0,1,0,0,-1,0,1};
int K=1;
void visit(char MAP[1005][1005],int x,int y){

    bool flag=false;
    if(MAP[x][y]=='#'){ 
    for(int i=0;i<4;i++){
            int X=x+dir[i][0];
            int Y=y+dir[i][1];//重新定義避免影響其他方向 
            
            if(MAP[X][Y]=='.') 
            {
            MAP2[x][y].drown=true;  
            }
            if(MAP[X][Y]=='#')
            {
                if(MAP2[X][Y].tag==false)flag=true;
                MAP2[X][Y].k=K;
            }
            MAP2[x][y].tag=true;
        }
        if(flag==false)K++;
        cout<<K<<"#"<<endl;
    }
} 



int main()
{
  scanf("%d",&n);
  for(int i=0;i<n;i++){
    scanf("%s",MAP[i]);
    for(int j=0;j<n;j++){
        if(MAP[i][j]=='#')
        {
            plain p;
            p.drown=p.tag=false;
            p.k=0;
            MAP2[i][j]=p;
        }
    }
}
for(int i=1;i<n-1;i++){
    for(int j=1;j<n-1;j++){
        visit(MAP,i,j);
    }
}
   for(int i=0;i<n;i++){
     for(int j=0;j<n;j++){
    printf("%d ",MAP2[i][j].k);
  }
  cout<<endl;
}
int drown_il=0;

for(int K2=1;K2<K;){
for(int i=1;i<n;i++){
     for(int j=1;j<n;j++){
        if(MAP[i][j]=='#')
        {
        if(MAP2[i][j].k==K2&&MAP2[i][j].drown==false)drown_il+=1;
        if(MAP2[i][j].k!=K2)K2++;
        }
     }
     
   }
}
cout<<drown_il<<endl;
  return 0;
}

第二遍倒是用了遞歸dfs……然鵝冕茅,按照我之前的思路統(tǒng)計(jì)島嶼個(gè)數(shù)落午,就是如果一片土地周圍除了海被訪問過的島,他就是這片島的最后一個(gè)……就是這個(gè)zz算法完全會(huì)把一個(gè)島切成2個(gè)啊
受不了自己的智商……就這樣吧 打印準(zhǔn)考證去了……

#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <vector>
using namespace std;
int n;
char MAP[1005][1005];
char MAP2[1005][1005];
int dir[4][2]={-1,0,1,0,0,-1,0,1};
int K=1;

void drown(int x,int y){
    for(int i=0;i<4;i++){
            cout<<"###"<<x<<y<<endl;
            int X=x+dir[i][0];
            int Y=y+dir[i][1];//重新定義避免影響其他方向 
            if(MAP2[X][Y]=='.'){
                cout<<"###"<<x<<y<<endl;
            MAP2[x][y]='^';
            }
        }
}
bool is_ilse(int x,int y){
    bool flag=true;
    for(int i=0;i<4;i++){
            int X=x+dir[i][0];
            int Y=y+dir[i][1];//重新定義避免影響其他方向 
            if(MAP2[X][Y]=='#')flag=false;
        }
        cout<<x<<" "<<y<<" falg"<<flag<<endl;
        if(flag==true)return 1;
        if(flag==false)return 0;
}

void dfs(int x,int y,int &count_p){
    if(is_ilse(x,y))
    {
        MAP2[x][y]='@';
    count_p++;
    return;
    }
    MAP2[x][y]=-1;
        for(int i=0;i<4;i++){
            int X=x+dir[i][0];
            int Y=y+dir[i][1];
            if(MAP2[X][Y] == '#'){
                dfs(X,Y,count_p);
            }
    }
} 

int main()
{
  scanf("%d",&n);
  for(int i=0;i<n;i++){
    scanf("%s",MAP[i]);
    }
for(int i=0;i<n;i++){
     for(int j=0;j<n;j++){
     MAP2[i][j]=MAP[i][j];
    }
}
int begin=0;
int end=0;

for(int i=1;i<n;i++){
     for(int j=1;j<n;j++){
        if(MAP2[i][j]=='#')
        dfs(i,j,begin);
    }
}
for(int i=0;i<n;i++){
     for(int j=0;j<n;j++){
        if(MAP[i][j]=='#')
        drown(i,j);
    }
}
   for(int i=0;i<n;i++){
     for(int j=0;j<n;j++){
    printf("%d ",MAP2[i][j]);
  }
  cout<<endl;
}
cout<<endl;
for(int i=0;i<n;i++){
     for(int j=0;j<n;j++){
        if(MAP[i][j]=='@')
        dfs(i,j,end);
    }
}
   for(int i=0;i<n;i++){
     for(int j=0;j<n;j++){
    printf("%d ",MAP2[i][j]);
  }
  cout<<endl;
}
cout<<begin<<" "<<end<<endl;

  return 0;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鲫咽,一起剝皮案震驚了整個(gè)濱河市赐稽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌浑侥,老刑警劉巖姊舵,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異寓落,居然都是意外死亡括丁,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門伶选,熙熙樓的掌柜王于貴愁眉苦臉地迎上來史飞,“玉大人,你說我怎么就攤上這事仰税」棺剩” “怎么了?”我有些...
    開封第一講書人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵陨簇,是天一觀的道長吐绵。 經(jīng)常有香客問我,道長河绽,這世上最難降的妖魔是什么己单? 我笑而不...
    開封第一講書人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮耙饰,結(jié)果婚禮上纹笼,老公的妹妹穿的比我還像新娘。我一直安慰自己苟跪,他們只是感情好廷痘,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著件已,像睡著了一般笋额。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上拨齐,一...
    開封第一講書人閱讀 52,262評(píng)論 1 308
  • 那天鳞陨,我揣著相機(jī)與錄音,去河邊找鬼。 笑死厦滤,一個(gè)胖子當(dāng)著我的面吹牛援岩,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播掏导,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼享怀,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了趟咆?” 一聲冷哼從身側(cè)響起添瓷,我...
    開封第一講書人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎值纱,沒想到半個(gè)月后鳞贷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡虐唠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年搀愧,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疆偿。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡咱筛,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出杆故,到底是詐尸還是另有隱情迅箩,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布处铛,位于F島的核電站饲趋,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏罢缸。R本人自食惡果不足惜篙贸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望枫疆。 院中可真熱鬧,春花似錦敷鸦、人聲如沸息楔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽值依。三九已至,卻和暖如春碟案,著一層夾襖步出監(jiān)牢的瞬間愿险,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留辆亏,地道東北人风秤。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像扮叨,于是被迫代替她去往敵國和親缤弦。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容