CODE[VS] 3411 洪水

題目描述?Description

小浣熊松松和朋友到野外露營,沒想到遇上了π年一次的大洪水,好在松松是一只愛觀察的小浣熊,他發現露營地的地形和洪水有如下性質:

①露營地可以被看做是一個N*M的矩形方陣,其中左上角坐標為(1,1),右下角坐標為(n,m),每個格子(i,j)都有一個高度h(i,j)。

②洪水送(r,c)開始,如果一個格子被洪水淹沒,那這個格子四周比它低(或相同)的格子也會被淹沒。

現在松松想請你幫忙算算,有多少個格子不會被淹沒,便于他和朋友逃脫。

【原有誤數據已刪除】

?

輸入描述?Input Description

第一行包含兩個整數n,m,表示矩形方陣右下角坐標。

以下n行,每行m個數,第i行第j個數表示格子(i,j)的高度。

最后一行包含兩個整數r,c,表示最初被洪水淹沒的格子。

輸出描述?Output Description

輸出僅一行,為永遠不會被淹沒的格子的數量。

?

樣例輸入?Sample Input

3 3

1 2 3

2 3 4

3 4 5

2 2

樣例輸出?Sample Output

5

?

數據范圍及提示?Data Size & Hint

對于90%的數據,保證隨機生成。

對于100%的數據,1<=N,M<=1000。

?

標簽是bfs,

我只會用dfs。

?

下面是dfs爆搜。

?

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;int n,m,h[1002][1002],a,b,ans=1;
int xx[5]={-1,1,0,0},yy[5]={0,0,1,-1};
bool w[1002][1002],vis[1002][1002];void dfs(int x,int y)
{vis[x][y]=1;for(int i=0;i<4;++i){int dx=x+xx[i],dy=y+yy[i];if(dx<1||dx>n||dy<1||dy>m||w[dx][dy]==1||vis[dx][dy]==1) continue;if(h[dx][dy]<=h[x][y]){w[dx][dy]=1;ans++;}}for(int i=1;i<=n;++i)for(int j=1;j<=m;++j)if(w[i][j]==1&&!vis[i][j]) dfs(i,j);
}int main()
{scanf("%d%d",&n,&m);for(int i=1;i<=n;++i)for(int j=1;j<=m;++j)scanf("%d",&h[i][j]);scanf("%d%d",&a,&b);w[a][b]=1;dfs(a,b);printf("%d",n*m-ans);
}
DFS75

?

?

這個也是dfs,還是很慢,不過能過這道題,

對比一下思路吧。

?

#include<cstdio>
#include<iostream>
using namespace std;int next[4][2]= {{0,1},{0,-1},{1,0},{-1,0}};
int mp[1000][1000];
int a[1000][1000];
int n,m,sum=0;void dfs(int x,int y)
{sum++;int t;t=mp[x][y];int i,j;for(i=0; i<4; i++){int xx=x+next[i][0];int yy=y+next[i][1];if(xx<1||yy<1||xx>n||yy>m)continue ;if(mp[xx][yy]<=t&&a[xx][yy]==0){a[xx][yy]=1;dfs(xx,yy);}}
}int main()
{int i,j;cin>>n>>m;for(i=1; i<=n; i++)for(j=1; j<=m; j++)cin>>mp[i][j];int x;int y;cin>>x>>y;a[x][y]=1;dfs(x,y);cout<<n*m-sum<<endl;return 0;
}
dfs AC

?

?

?

有人說這是個bfs的板子。

hh,反正我不會。

狗子zxl又在外面發火了。。。

?

另附一份bfsAC代碼。

自行理解。

?

#include<iostream>
#include<queue>
using namespace std;struct point
{int x,y;
};int dir[4][2]= {{-1,0},{1,0},{0,-1},{0,1}};
int lock[1001][1001] = {0};
int a[1001][1001];
int n, m, sum=0;void BFS(int x, int y)
{queue <point> q;point now,  next;now.x = x,   now.y = y;q.push(now);lock[now.x][now.y] = -1;while(!q.empty()){now = q.front();for(int i=0; i<4; i++){next.x = now.x + dir[i][0];next.y = now.y + dir[i][1];if(next.x<=0||next.y<=0||next.x>n||next.y>m) //判斷是否越界continue;if((a[next.x][next.y]<=a[now.x][now.y])&&lock[next.x][next.y]!=-1)//如果洪水可以淹沒,且點沒有訪問過
            {q.push(next);  //該點入棧lock[next.x][next.y] = -1;}}q.pop();sum++;}
}int main()
{int p1, p2;cin>>n>>m;for(int i=1; i<=n; i++){for(int j=1; j<=m; j++)cin>>a[i][j];}cin>>p1>>p2;BFS(p1,p2);cout<<n*m-sum<<endl;return 0;
}
bfs

?

?

?

?

?

?

轉載于:https://www.cnblogs.com/Mary-Sue/p/9163418.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/251605.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/251605.shtml
英文地址,請注明出處:http://en.pswp.cn/news/251605.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

JavaScript --- 取得鼠標事件的坐標

說明: clientX和clientY屬性&#xff1a;事件發生時,鼠標指針在視口中的水平和垂直坐標。pageX和pageY屬性&#xff1a;鼠標光標在頁面中的位置。screenX和screenY屬性&#xff1a;鼠標事件發生時&#xff0c;鼠標指針相對于整個屏幕的坐標信息。IE8及更早的版本不支持事件對象…

JavaScript語義基礎

變量&#xff08;Variables&#xff09; Variables是你存儲數據的容器。聲明一個變量需要使用關鍵字var&#xff0c;然后輸入變量的名稱。 1 var myvar; 定義一個變量后&#xff0c;可以賦予變量一個值&#xff1a; 1 myvar "mxp"; 可以將上述操作寫在一行&#x…

spring面試專題一點通,再也不用擔心面試不會回答了

前言文章內容有點小長&#xff0c;希望你能耐心閱讀&#xff0c;更多Java面試題以及學習資料獲取方式&#xff1a;加Qun:1017-599-436免費獲取。還有更多包括電子書&#xff0c;PDF文檔以及視頻精講可以分享給大家&#xff0c;內容覆蓋很廣&#xff0c;分布式緩存、RPC 調用、Z…

bzoj4033 [HAOI2015]樹上染色

題目&#xff1a;https://www.lydsy.com/JudgeOnline/problem.php?id4033 重要的思路&#xff1a;與其考慮每一個點對的貢獻&#xff0c;不如考慮每條邊的貢獻&#xff08;被經過了幾次&#xff09;&#xff01; 樹形dp。 總共的黑點和白點的個數都是已知的&#xff0c;所以知…

JavaScript --- 表單focus,blur,change事件的實現

假設有一個文本框&#xff0c;我們只允許用戶輸入數值。為此&#xff0c;我們希望: 1.利用focus事件修改文本框內容&#xff0c; 2.利用blur事件回復文本框的內容, 3.利用change事件在用戶輸入了非數值字符時再次修改背景顏色。 var EventUtil {addHandler: function(element…

mysql日期格式轉化

select DATE_FORMAT( 20170701, %Y-%m-%d);先挖坑轉載于:https://www.cnblogs.com/tuhooo/p/7766221.html

Solr管理頁面 上

DashBoard&#xff08;儀表盤&#xff09;Logging&#xff08;日志&#xff09;Core Admin&#xff08;Core管理&#xff09;在Solr中&#xff0c;每一個Core&#xff0c;代表一個索引庫&#xff0c;里面包含索引數據及其配置信息。Solr中可以擁有多個Core&#xff0c;也就同時…

GRPC協議的相關原理

GRPC的Client與Server&#xff0c;均通過Netty Channel作為數據通信&#xff0c;序列化、反序列化則使用Protobuf&#xff0c;每個請求都將被封裝成HTTP2的Stream&#xff0c;在整個生命周期中&#xff0c;客戶端Channel應該保持長連接&#xff0c;而不是每次調用重新創建Chann…

Echarts --- 各個省份的坐標

純手打…效果如下 1.新疆: [86.61 , 40.79] 2.西藏:[89.13 , 30.66] 3.黑龍江:[128.34 , 47.05] 4.吉林:[126.32 , 43.38] 5.遼寧:[123.42 , 41.29] 6.內蒙古:[112.17 , 42.81] 7.北京:[116.40 , 40.40 ] 8.寧夏:[106.27 , 36.76] 9.山西:[111.95,37.65] 10.河北:[115.21 , 38.…

xxx征集系統項目目標文檔

問題 每四人一組&#xff0c;討論結束后&#xff0c;每人根據課堂討論結果提交一份系統利益相關者案例。撰寫撰寫項目目標文檔&#xff08;目標&#xff0c;好處&#xff0c;度量標準。&#xff09; 項目目標文檔 目標&#xff1a; &#xff08;1&#xff09;需求填報 &#xf…

高并發大流量專題---10、MySQL數據庫層的優化

高并發大流量專題---10、MySQL數據庫層的優化 一、總結 一句話總結&#xff1a; mysql先考慮做分布式緩存&#xff0c;過了緩存后就做mysql數據庫層面的優化 1、mysql數據庫層的優化的前面一層是什么&#xff1f; 數據庫緩存&#xff1a;突破了數據庫緩存就需要做mysql數據庫層…

【彩彩只能變身隊】后端工作總結

2018.06.09 早上8點到晚上10點 沖刺前后端交互(vueexpressmysql) 8&#xff1a;00-12&#xff1a;00 &#xff1a; 前端把請求寫好&#xff1a; <template> <div class"LoginForm"> <el-form ref"form" label-width"80px"…

web安全

web安全 DOS命令 web攻防必備課筆記 慕課xss學習 阮一峰&#xff1a;MVC、MVP和MVVM的圖示轉載于:https://www.cnblogs.com/hanxuming/p/7774092.html

JavaScript --- 渲染數據量大的數組

很多時候&#xff0c;需要在頁面上展示從后臺來的大量數據,如果一次性渲染&#xff0c;會影響用戶的體驗。(而且瀏覽器中的JS嚴格限制了資源) /* *使用分組的思想來渲染大量的數組 *parmas array 要處理的數組 *params process 對數組中每一個item進行的操作 *parmas context …

Jquery操作select小結

每次操作select都要查資料&#xff0c;干脆總結一下。 為select設置placeholder <select class"form-control selOP" placeholder"Pick Orchestration Plan"><option value"" disabled selected styledisplay:none;>Pick Orchestrat…

第六講:PrintClient工具的使用

一些簡單命令&#xff1a; cp -rf 源目錄 目的目錄 chmod -R 777 文件名 motelist 查看節點路徑 make telosb 編譯代碼 make telosb reinstall 下載但不編譯 make telosb install 編譯并且下載 make telosb install, 2 bsl,/dev/ttyUSB0 下載指定路徑 java net.tinyos.tools.Li…

SQL Server

查看數據庫服務器名稱&#xff1a;tracert 192.168.10.01 轉載于:https://www.cnblogs.com/hongwei2085/p/9174760.html

css --- 選擇器

標簽選擇器 // 標簽選擇器是最簡單的選擇器, 它的命名只要和對應的HTML標簽相同即可 h1 {font-size: 30px;color: #333; }類選擇器 // 類選擇器也稱為class選擇器,它的語法非常簡單,在class名稱前面加上一個"."符號 <div class"red content"></…

C++標準輸入流、輸出流以及文件流

1、流的控制 iomanip 在使用格式化I/O時應包含此頭文件。 stdiostream 用于混合使用C和C 的I/O機制時&#xff0c;例如想將C程序轉變為C程序 2、類繼承關系 ios是抽象基類&#xff0c;由它派生出istream類和ostream類&#xff0c; iostream類支持輸入輸出操作&…

Hadoop學習筆記—8.Combiner與自定義Combiner

一、Combiner的出現背景 1.1 回顧Map階段五大步驟 在第四篇博文《初識MapReduce》中&#xff0c;我們認識了MapReduce的八大步湊&#xff0c;其中在Map階段總共五個步驟&#xff0c;如下圖所示&#xff1a; 其中&#xff0c;step1.5是一個可選步驟&#xff0c;它就是我們今天需…