当前位置: 首页 > news >正文

html怎么做网站设计定制型网站建设合同范本

html怎么做网站设计,定制型网站建设合同范本,企业网站建设公司电话,seo搜索引擎优化推广968.监控二叉树 给定一个二叉树#xff0c;我们在树的节点上安装摄像头。 节点上的每个摄影头都可以监视其父对象、自身及其直接子对象。 计算监控树的所有节点所需的最小摄像头数量。 示例 1#xff1a; 输入#xff1a;[0,0,null,0,0] 输出#xff1a;1 解释#xff…968.监控二叉树 给定一个二叉树我们在树的节点上安装摄像头。 节点上的每个摄影头都可以监视其父对象、自身及其直接子对象。 计算监控树的所有节点所需的最小摄像头数量。 示例 1 输入[0,0,null,0,0] 输出1 解释如图所示一台摄像头足以监控所有节点。示例 2 输入[0,0,null,0,null,0,null,null,0] 输出2 解释需要至少两个摄像头来监视树的所有节点。 上图显示了摄像头放置的有效位置之一。提示 给定树的节点数的范围是 [1, 1000]。每个节点的值都是 0。 思路 想半天想不出来然后去看了各路大神的题解对比之下发现官方题解的说法完全是在冒充人类。 首先我们先要确定从二叉树的下面往上看为什么不自顶向下呢因为头节点放不放摄像头也就省下一个摄像头但是叶子节点放不放摄像头省下的是指数级的摄像头。 那么从下往上看我们首先想到的是二叉树的后序遍历法左-右-中所以本题我们使用递归法来解。 并且如果要达成局部最优的话我们一定是在叶子节点的父节点安装摄像头让所用摄像头最少达成全局最优。 所以大体思路就是从低向上遍历二叉树先给叶子节点父节点放摄像头然后隔两个节点放一个摄像头直到到根节点。 但是怎样隔两个节点放一个摄像头呢此时我们就需要状态转移的公式来记录每个节点的状态。每个节点可能有三种状态 0该节点无覆盖 1该节点有摄像头 2该节点有覆盖 空节点一律视为有覆盖的情况因为若把空节点视为无覆盖那么空节点的父节点——叶子节点就必须放置一个摄像头这与本意冲突若把空节点视为有摄像头那么叶子节点就为有覆盖那么隔两个节点才会放一个摄像头实际上没有监控到叶子节点所以空节点只能视为有覆盖。 那么对于每个节点的处理逻辑我们可以分为四类情况 1、左右节点都有覆盖该节点一定无覆盖 2、左右节点至少有一个无覆盖该节点一定放摄像头 3、左右节点至少有一个摄像头该节点一定有覆盖 4、头节点无覆盖头节点再加一个摄像头。 代码 class Solution {int res0;public int minCameraCover(TreeNode root) {return dfs(root)0?res1:res;}private int dfs(TreeNode node){if(nodenull){return 2;}int leftdfs(node.left);int rightdfs(node.right);if(left0||right0){res;return 1;}if(left1||right1){return 2;}return 0;}} 灵茶山艾府的思路我没理解二刷的时候再研究。 509.斐波那契数 斐波那契数 通常用 F(n) 表示形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始后面的每一项数字都是前面两项数字的和。也就是 F(0) 0F(1)  1 F(n) F(n - 1) F(n - 2)其中 n 1给定 n 请计算 F(n) 。 示例 1 输入n 2 输出1 解释F(2) F(1) F(0) 1 0 1示例 2 输入n 3 输出2 解释F(3) F(2) F(1) 1 1 2示例 3 输入n 4 输出3 解释F(4) F(3) F(2) 2 1 3提示 0 n 30 思路 经典递归解法 class Solution {public int fib(int n) {if(n1){return 1;}else if(n0){return 0;}else {return fib(n-1)fib(n-2);}}} dp解法 确定dp数组含义 dp[i]的定义为第i个数的斐波那契数值为dp[i] 递推公式dp[i] dp[i - 1] dp[i - 2]; 初始化dp[0]0,dp[1]1 代码 class Solution {public int fib(int n) {if (n 1) return n; int[] dp new int[n 1];dp[0] 0;dp[1] 1;for (int index 2; index n; index){dp[index] dp[index - 1] dp[index - 2];}return dp[n];} } 空间复杂度可以进一步优化因为不用维护整个dp数组 class Solution {public int fib(int n) {if (n 2) return n;int a 0, b 1, c 0;for (int i 1; i n; i) {c a b;a b;b c;}return c;} }
http://www.hkea.cn/news/14555477/

相关文章:

  • 织梦网站模板免费下载wordpress该域名
  • 为什么网页制作图片显示不出来网站seo综合查询
  • 网站做照片上海本土互联网公司
  • 东南亚cod建站工具洛阳专注网站建设的公司
  • 企业网站建设深圳网站建设的利益
  • 网站建设的领军 18年网站建设公众号小程序是什么
  • 宁波网站建设优化诊断做展馆好的设计网站
  • 网站建设方案及预算桂林网站制作哪家公司好
  • 新老网站做301跳转淘宝网页版登录入口官方
  • 徐州做网站企业域名地址查询
  • 苍溪县建设局网站wordpress不能启动怎么解决
  • 西安商城网站建设咪豆新洲网站建设
  • 网站搭建制作公司电商网站建设代码大全
  • 在html中做网站 视频网络公司网页设计
  • 软文素材网站合肥光束网站建设
  • 网站建设费算广告费吗wordpress获取文章列表
  • 网站 建设运行情况学做ps的软件的网站有哪些
  • 网站地图表现形式软件自学网站
  • 用html建设网站网站这么设置微信支付
  • 微信微网站模板下载江门网站开发公司
  • 北京优化seo排名优化德州哪家网站优化好
  • 设计师网站十大网站推荐共享网站哪里建
  • 沈阳网站制作公司思路wordpress图文并排
  • 北京网站建设报价明细qq群推广引流
  • 网站宣传推广平台1个云虚拟主机怎么做多个网站
  • 视频网站seo实战asp网站开发流程
  • 网站开发的基础是什么kfk wordpress
  • 国外优秀ui设计网站wordpress 4.0后台
  • 肥东建设局网站网站seo推广软件
  • 做空调管路网站出售app软件的平台