#KE021. 山峰和山谷

山峰和山谷

【问题描述】

给定一个 n×n 的网格状地图,每个方格 (i,j) 有一个高度 wij。如果两个方格有公共顶点,则它们是相邻的。定义山峰和山谷如下:

均由地图上的一个连通块组成;( 连通块:一个区域内方格高度相同且8个方向连通) 连通块相邻的格子高度均大于此连通块,此连通块为山谷;连通块相邻的格子高度均小于此连通块,此连通块为山峰;连通块相邻的格子里既有大于当前连通块高度的格子也有小于当前连通块高度的格子,此连通块既不是山峰也不是山谷。 求地图内山峰和山谷的数量。特别地图,如果整个地图方格的高度均相同,则整个地图既是一个山谷,也是一个山峰。

【输入格式】

第一行一个整数 n (2≤n≤1000),表示地图的大小。

接下来 n 行每行 n 个整数表示地图。第 i 行有 n 个整数 wi1, wi2,… win(0≤wij≤1 000 000 000),表示地图第 i 行格子的高度。

【输出格式】

输出一行两个整数,分别表示山峰和山谷的数量。

测试样例

5
8 8 8 7 7
7 7 8 8 7
7 7 7 7 7
7 8 8 7 8
7 8 8 8 8
2 1