【bfs】BZOJ1102- [POI2007]山峰和山谷Grz

最后刷个水,睡觉去。Bless All!

【题目大意】

给定一个地图,为FGD想要旅行的区域,地图被分为n*n的网格,每个格子(i,j) 的高度w(i,j)是给定的。
若两个格子有公共顶点,那么他们就是相邻的格子。(所以与(i,j)相邻的格子有(i?1, j?1),(i?1,j),(i?1,j+1),(i,j?1),(i,j+1),(i+1,j?1),(i+1,j),(i+1,j+1))。
我们定义一个格子的集合S为山峰(山谷)当且仅当:
1.S的所有格子都有相同的高度。
2.S的所有格子都联通
3.对于s属于S,与s相邻的s’不属于S。都有ws > ws’(山峰),或者ws < ws’(山谷)。
你的任务是,对于给定的地图,求出山峰和山谷的数量,如果所有格子都有相同的高度,那么整个地图即是山峰,又是山谷。

【思路】

普通的bfs。判断是否是山峰和山谷的方法就是如果周围和它们不等高,那么就记下比它们高还是比它们低。最后如果统一高,就是山谷;统一低,就是山峰。

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 const int MAXN=1000+5;
 4 int w[MAXN][MAXN],vis[MAXN][MAXN];
 5 int peak,valley,higher,lower,n;
 6 int dx[8]={1,1,1,-1,-1,-1,0,0};
 7 int dy[8]={0,1,-1,0,1,-1,1,-1};
 8 struct node
 9 {
10     int x,y;
11 };
12 queue<node> que;
13
14 void init()
15 {
16     peak=valley=0;
17     scanf("%d",&n);
18     for (int i=1;i<=n;i++)
19         for (int j=1;j<=n;j++) scanf("%d",&w[i][j]);
20 }
21
22 void bfs(int x,int y)
23 {
24     lower=higher=0;
25     while (!que.empty()) que.pop();
26     que.push((node){x,y});
27     vis[x][y]=1;
28     while (!que.empty())
29     {
30         int hx=que.front().x,hy=que.front().y;
31         que.pop();
32         for (int i=0;i<8;i++)
33         {
34             int xx=hx+dx[i],yy=hy+dy[i];
35             if (xx<=0 || xx>n || yy<=0 || yy>n) continue;
36             if (w[xx][yy]==w[hx][hy] && !vis[xx][yy])
37             {
38                 que.push((node){xx,yy});
39                 vis[xx][yy]=1;
40             }
41             else
42             {
43                 if (w[xx][yy]>w[hx][hy]) higher++;
44                     else if (w[xx][yy]<w[hx][hy]) lower++;
45             }
46         }
47     }
48     if (higher==0 && lower!=0) peak++;
49     if (lower==0 && higher!=0) valley++;
50 }
51
52 void solve()
53 {
54     memset(vis,0,sizeof(vis));
55     for (int i=1;i<=n;i++)
56         for (int j=1;j<=n;j++)
57             if (!vis[i][j]) bfs(i,j);
58     if (!peak && !valley) peak=valley=1;
59     printf("%d %d\n",peak,valley);
60 }
61
62 int main()
63 {
64     init();
65     solve();
66     return 0;
67 } 
时间: 2024-10-13 05:35:01

【bfs】BZOJ1102- [POI2007]山峰和山谷Grz的相关文章

BZOJ1102: [POI2007]山峰和山谷Grz

1102: [POI2007]山峰和山谷Grz Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 436  Solved: 227[Submit][Status] Description FGD小朋友特别喜欢爬山,在爬山的时候他就在研究山峰和山谷.为了能够让他对他的旅程有一个安排,他想知道山峰和山谷的数量. 给定一个地图,为FGD想要旅行的区域,地图被分为n*n的网格,每个格子(i,j) 的高度w(i,j)是给定的. 若两个格子有公共顶点,那么他们就

【BZOJ 1102】 [POI2007]山峰和山谷Grz

1102: [POI2007]山峰和山谷Grz Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 495  Solved: 263 [Submit][Status][Discuss] Description FGD小朋友特别喜欢爬山,在爬山的时候他就在研究山峰和山谷.为了能够让他对他的旅程有一个安排,他想知道山峰和山谷的数量. 给定一个地图,为FGD想要旅行的区域,地图被分为n*n的网格,每个格子(i,j) 的高度w(i,j)是给定的. 若两个格子

BZOJ 1102 POI2007 山峰和山谷Grz Floodfill

题目大意:给定一张地势图,求山峰和山谷的数量 直接Floodfill--注意DFS会爆栈,用BFS才能过 #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define M 1010 using namespace std; int n,ans1,ans2,a[M][M]; bool flag,v[M][M]; /* void Floodfill(in

[POI2007]山峰和山谷Grz

Description FGD小朋友特别喜欢爬山,在爬山的时候他就在研究山峰和山谷.为了能够让他对他的旅程有一个安排,他想知道山峰和山谷的数量.给定一个地图,为FGD想要旅行的区域,地图被分为\(n\times n\)的网格,每个格子(i,j) 的高度w(i,j)是给定的.若两个格子有公共顶点,那么他们就是相邻的格子.(所以与(i,j)相邻的格子有(i-1, j-1),(i-1,j),(i-1,j+1),(i,j-1),(i,j+1),(i+1,j-1),(i+1,j),(i+1,j+1)).我

山峰和山谷 Ridges and Valleys

题目描述 思路 一开始看这道题目,也不是很会,谁会把统计之类的问题和bfs联系在一起,没有开始的状态,没有结束的状态,题目中连一个最短之类的词也没有出现. 然后统计嘛,题目中说了方格高度都相同,就把周围的点都看一遍和这个点高度相同的就入队,把高度相同的点都打上浏览的标记.看的过程中,既有比它小的,也有比它大的,那么这种高度的点就不是我们要统计的答案,只有比它小的,或只有比它大的,那么就是我们要统计的.可以设置两个标记,标记看的过程中有没有比它小的,比它大的. 然后就是只有一个高度的时候,因为两个

(BFS) bzoj 1102

1102: [POI2007]山峰和山谷Grz Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 436  Solved: 227[Submit][Status] Description FGD小朋友特别喜欢爬山,在爬山的时候他就在研究山峰和山谷.为了能够让他对他的旅程有一个安排,他想知道山峰和山谷的数量.给定一个地图,为FGD想要旅行的区域,地图被分为n*n的网格,每个格子(i,j) 的高度w(i,j)是给定的.若两个格子有公共顶点,那么他们就是相

1281 山峰和旗子

用一个长度为N的整数数组A,描述山峰和山谷的高度.山峰需要满足如下条件, 0 < P < N - 1 且 A[P - 1] < A[P] > A[P + 1]. 现在要在山峰上插上K个旗子,并且每个旗子之间的距离 >= K,问最多能插上多少个旗子(即求K的最大值).两个山峰之间的距离为|P - Q|. 以上图为例,高度为:1 5 3 4 3 4 1 2 3 4 6 2.其中可以作为山峰的点为:1 3 5 10. 放2面旗子, 可以放在1 和 5. 放3面旗子, 可以放在1 5

P3456 [POI2007]GRZ-Ridges and Valleys

题意翻译 给定一个地图,为小朋友想要旅行的区域,地图被分为n*n的网格,每个格子(i,j) 的高度w(i,j)是给定的.若两个格子有公共顶点,那么他们就是相邻的格子.(所以与(i,j)相邻的格子有(i-1, j-1),(i-1,j),(i-1,j+1),(i,j-1),(i,j+1),(i+1,j-1),(i+1,j),(i+1,j+1)).我们定义一个格子的集合S为山峰(山谷)当且仅当: 1.S的所有格子都有相同的高度. 2.S的所有格子都联通3.对于s属于S,与s相邻的s’不属于S.都有ws

51Nod1285 山峰和分段

Problem 用一个长度为N的整数数组A,描述山峰和山谷的高度.山峰需要满足如下条件, 0 < P < N - 1 且 A[P - 1] < A[P] > A[P + 1]. 现在要将整个山分为K段,要求每段的点数都一样,且每段中都至少存在一个山峰,问最多可以分为多少段. Solution 枚举因数,前缀和优化查询. 复杂度是因子之和,试了一下,1e6之内一个大于5*n的也没有,最大比率4.5多一点. Code #include<stdio.h> #include&l