题目戳我

\(\text{Solution:}\)

好久没写啥\(dfs\)了,借这个题整理下细节。

观察到答案具有二分性,所以先求出其差的最大最小值,\(\log val\)的复杂度不成问题。

考虑如何\(check:\)

考虑一个\(dfs\)预处理当前点为\((i,j),\)高度为\(k\)所能到达的所有点。这一步是\(n^2\)的复杂度。注意判断是否出界的时候符号不要打反,以及这题所谓高度差是在绝对值意义上的。

遍历变量时不要重名。之所以每次不需要清空\(vis\)是因为每次\(dfs\)都会保证找齐一个点所能到达的所有点。

于是,这题可以在\(O(n^2\log m)\)的复杂度完成。

还有一个想法是求出原树的最小生成树后处理出\(siz\)和子树的最大差。然后可以\((n^2\log n^2)\)实现这题。

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int MAXN=5e5+10;
  4. int a[501][501],n;
  5. const int dx[4]={1,0,-1,0};
  6. const int dy[4]={0,1,0,-1};
  7. int L,R,ans,vis[501][501];
  8. int dfs(int x,int y,int kk){
  9. int cnt=1;
  10. vis[x][y]=1;
  11. for(int k=0;k<4;++k){
  12. int nx=x+dx[k],ny=y+dy[k];
  13. if(nx<1||ny<1||nx>n||ny>n||vis[nx][ny]||abs(a[x][y]-a[nx][ny])>kk)continue;
  14. cnt+=dfs(nx,ny,kk);
  15. }
  16. return cnt;
  17. }
  18. bool check(int k){
  19. memset(vis,0,sizeof vis);
  20. for(int i=1;i<=n;++i)
  21. for(int j=1;j<=n;++j){
  22. if(vis[i][j])continue;
  23. int C=dfs(i,j,k);
  24. if(C*2>=n*n)return true;
  25. }
  26. return false;
  27. }
  28. int main(){
  29. scanf("%d",&n);
  30. L=(1<<30);R=-L;
  31. for(int i=1;i<=n;++i)
  32. for(int j=1;j<=n;++j)
  33. scanf("%d",&a[i][j]);
  34. for(int i=1;i<=n;++i){
  35. for(int j=1;j<=n;++j){
  36. for(int k=0;k<4;++k){
  37. int x=i+dx[k],y=j+dy[k];
  38. R=max(R,a[i][j]-a[x][y]);
  39. L=min(L,a[i][j]-a[x][y]);
  40. }
  41. }
  42. }
  43. while(L<=R){
  44. int mid=L+R>>1;
  45. if(check(mid))ans=mid,R=mid-1;
  46. else L=mid+1;
  47. }
  48. printf("%d\n",ans);
  49. return 0;
  50. }

【题解】[USACO13FEB]Tractor S的更多相关文章

  1. [USACO13FEB] Tractor

    题目链接 大家的 Blog 里面都是做过的题目,只有我的里面什么都没有 那我也开始写一点吧 刷着刷着 DP 不知怎的就出来一道这个题……用时 2 hours 后怒而删两个文件重构…… 然后过了……过了 ...

  2. [USACO13FEB]出租车Taxi

    洛谷题目链接:[USACO13FEB]出租车Taxi 题目描述 Bessie is running a taxi service for the other cows on the farm. The ...

  3. [bzoj3062][Usaco13Feb]Taxi_贪心

    Taxi bzoj-3062 Usaco13Feb 题目大意:有n个奶牛想坐出租车.第i头奶牛在起点a[i]等候,想坐出租车到b[i].Bessie从0出车,车上只能坐一头奶牛.她必须完成所有奶牛的要 ...

  4. USACO Tractor

    洛谷 P3073 [USACO13FEB]拖拉机Tractor 洛谷传送门 JDOJ 2351: USACO 2013 Feb Silver 2.Tractor JDOJ传送门 题意翻译 题目描述 F ...

  5. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  6. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  7. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  8. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  9. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

随机推荐

  1. P3419 [POI2005]SAM-Toy Cars

    Description ​ Jasio 是一个三岁的小男孩,他最喜欢玩玩具了,他有n 个不同的玩具,它们都被放在了很高的架子上所以Jasio 拿不到它们. 为了让他的房间有足够的空间,在任何时刻地板上 ...

  2. Stone(思维)

    链接:https://ac.nowcoder.com/acm/contest/893/D来源:牛客网 题目描述 有n堆石子排成一排,第i堆石子有aiai个石子. 每次,你可以选择任意相邻的两堆石子进行 ...

  3. Linux服务器关联Git,通过执行更新脚本实现代码同步

    1.在Linux服务器安装Git yum install git -y   tips: 卸载Git :  yum remove git   2.在Linux生成ssh key   1)创建用户 git ...

  4. Poi Excel 设置列宽计算公式

    int width = 40;sheet.setColumnWidth(0,252*width+323); 作者:彼岸舞 时间:2020\07\27 内容关于:工作中用到的小技术 本文来源于网络,只做 ...

  5. 用笛卡尔积来创建一千六百万大表 整体19分钟 大表建成两分钟 设置id13分钟

    昨天拙文中讲述了用自增方式创建一千六百万大表的方案,这回讨论的是用笛卡儿积,实践证明这种方案更快. 2020年3月15日08点58分实验开始 创建仅有四千数据的tb_4thousand1表: SQL& ...

  6. 洛谷P1712 [NOI2016]区间 尺取法+线段树+离散化

    洛谷P1712 [NOI2016]区间 noi2016第一题(大概是签到题吧,可我还是不会) 链接在这里 题面可以看链接: 先看题意 这么大的l,r,先来个离散化 很容易,我们可以想到一个结论 假设一 ...

  7. 云计算openstack——虚拟机获取不到ip(13)

    一.现象描述: openstack平台中创建虚拟机后,虚拟机在web页面中显示获取到了ip,但是打开虚拟机控制台后查看网络状态,虚拟机没有ip地址,下图为故障截图: 二.分析思路: (1)查看neut ...

  8. 【Nginx】冰河又一本超硬核Nginx PDF教程免费开源!!

    写在前面 在 [冰河技术] 微信公众号中的[Nginx]专题,更新了不少文章,有些读者反馈说,在公众号中刷 历史文章不太方便,有时会忘记自己看到哪一篇了,当打开一篇文章时,似乎之前已经看过了, 但就是 ...

  9. nginx upstream一致性哈希的实现

    地址:http://wiki.nginx.org/HttpUpstreamConsistentHash 首先声明一个命令: static ngx_command_t  ngx_http_upstrea ...

  10. MaaS系统概述

    摘要:共享经济正改变着人们的生活方式,城市公共交通系统应该顺应共享经济的潮流进行转型.近年来,西方国家提出的“出行即服务(MaaS)”理念为我国解决日益严重的城市交通拥堵问题提供了新的思路.基于Maa ...