博客
关于我
【ybtoj】【BFS】【例题2】山峰和山谷
阅读量:319 次
发布时间:2019-03-04

本文共 1219 字,大约阅读时间需要 4 分钟。

【例题2】山峰和山谷


Link


解题思路

一开始就是有点理解错题意了,对就酱,调了半个小时,一整个就是失语极了

周围只有高的,就是山谷

周围只有矮的,就是山峰
有高有矮,谷、峰都不是
没高没矮是山谷也是山峰


Code

#include 
#include
using namespace std;const int way[8][2] = { { -1, 0}, { 1, 0}, { 0, -1}, { 0, 1}, { -1, -1}, { -1, 1}, { 1, -1}, { 1, 1}};int n, a[1010][1010], v[1010][1010], q[1000100][2], h, t, maxn, minn, ans_max, ans_min;bool check(int x,int y) { return (x > 0 && x <= n && y > 0 && y <= n);}void BFS(int x, int y) { maxn = minn = h = t = 0; q[++t][0] = x, q[t][1] = y; while (h++ < t) { for (int i = 0; i < 8; i++) { int xx = q[h][0] + way[i][0]; int yy = q[h][1] + way[i][1]; if (check(xx, yy)) { if (a[xx][yy] == a[x][y]) { if (!v[xx][yy]) { v[xx][yy] = 1; q[++t][0] = xx, q[t][1] = yy; } }else { if (a[xx][yy] > a[x][y]) maxn++;//统计周围高的 if (a[xx][yy] < a[x][y]) minn++;//统计周围矮的 } } } } if (!minn) ans_min++;//周围没有矮的就是山峰 if (!maxn) ans_max++;//周围没有高的就是山谷}int main() { scanf("%d", &n); for (int i = 1; i <= n; i++) for (int j = 1; j <= n; j++) scanf ("%d", &a[i][j]); for (int i = 1; i <= n; i++) for (int j = 1; j <= n; j++) if (!v[i][j]) BFS(i, j); printf("%d %d", ans_max, ans_min); }

转载地址:http://kyiq.baihongyu.com/

你可能感兴趣的文章
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
MySQL 中的外键检查设置:SET FOREIGN_KEY_CHECKS = 1
查看>>
Mysql 中的日期时间字符串查询
查看>>
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>