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

泰安做网站建设的公司网店推广常用的方法

泰安做网站建设的公司,网店推广常用的方法,网站优化排名,wordpress建站seo好做吗738. 单调递增的数字 当且仅当每个相邻位数上的数字 x 和 y 满足 x < y 时&#xff0c;我们称这个整数是单调递增的。 给定一个整数 n &#xff0c;返回 小于或等于 n 的最大数字&#xff0c;且数字呈 单调递增 。 示例 1: 输入: n 10 输出: 9 思路: 假设这个数是98,…

738. 单调递增的数字

当且仅当每个相邻位数上的数字 x 和 y 满足 x <= y 时,我们称这个整数是单调递增的。

给定一个整数 n ,返回 小于或等于 n 的最大数字,且数字呈 单调递增 。

示例 1:

输入: n = 10
输出: 9

思路:

假设这个数是98,n[i]>n[i+1],让n[i]--,n[i+1]=9,即98的单调递增数就是89

如果从前往后遍历,n[i+1]不仅受n[i]影响,还受n[i+2]影响,例如332->329 这时 3又比2大了

如果从后往前遍历,332->329->299,重复利用了上一次的结果

总体来说,从后往前遍历,遇见n[i]<n[i+1]的情况,让n[i]-1,让i+1与之后的位置都变为9

class Solution {public int monotoneIncreasingDigits(int n) {String s=String.valueOf(n);char[] chars=s.toCharArray();int index=s.length();//记录开始填9的位置for(int i=chars.length-2;i>=0;i--){if(chars[i]>chars[i+1]){chars[i]--;index=i+1;}}for(int i=index;i<s.length();i++ ){chars[i]='9';}return Integer.parseInt(String.valueOf(chars));}
}

968. 监控二叉树

给定一个二叉树,我们在树的节点上安装摄像头。

节点上的每个摄影头都可以监视其父对象、自身及其直接子对象。

计算监控树的所有节点所需的最小摄像头数量。

示例 1:

输入:[0,0,null,0,0]
输出:1
解释:如图所示,一台摄像头足以监控所有节点。

示例 2:

输入:[0,0,null,0,null,0,null,null,0]
输出:2
解释:需要至少两个摄像头来监视树的所有节点。 上图显示了摄像头放置的有效位置之一。


提示:

  1. 给定树的节点数的范围是 [1, 1000]
  2. 每个节点的值都是 0。

思路:

把摄像头优先放在叶节点的父节点上

所以我们要从下往上看,局部最优:让叶子节点的父节点安摄像头,所用摄像头最少,整体最优:全部摄像头数量所用最少!

在二叉树中如何从低向上推导呢?

可以使用后序遍历也就是左右中的顺序,这样就可以在回溯的过程中从下到上进行推导了。

如何隔两个节点放一个摄像头?

我们分别有三个数字来表示:

  • 0:该节点无覆盖
  • 1:本节点有摄像头
  • 2:本节点有覆盖

遇见空结点怎么办?

 空节点的状态只能是有覆盖,这样就可以在叶子节点的父节点放摄像头了

单层递归逻辑: 

  • 情况1:左右节点都有覆盖

左孩子有覆盖,右孩子有覆盖,那么此时中间节点应该就是无覆盖的状态了。

  • 情况2:左右节点至少有一个无覆盖的情况

如果是以下情况,则中间节点(父节点)应该放摄像头:

  • left == 0 && right == 0 左右节点无覆盖
  • left == 1 && right == 0 左节点有摄像头,右节点无覆盖
  • left == 0 && right == 1 左节点有无覆盖,右节点摄像头
  • left == 0 && right == 2 左节点无覆盖,右节点覆盖
  • left == 2 && right == 0 左节点覆盖,右节点无覆盖

这个不难理解,毕竟有一个孩子没有覆盖,父节点就应该放摄像头。

此时摄像头的数量要加一,并且return 1,代表中间节点放摄像头。

  • 情况3:左右节点至少有一个有摄像头

如果是以下情况,其实就是 左右孩子节点有一个有摄像头了,那么其父节点就应该是2(覆盖的状态)

  • left == 1 && right == 2 左节点有摄像头,右节点有覆盖
  • left == 2 && right == 1 左节点有覆盖,右节点有摄像头
  • left == 1 && right == 1 左右节点都有摄像头

情况4:头结点没有覆盖

以上都处理完了,递归结束之后,可能头结点 还有一个无覆盖的情况

这时要给根节点加上摄像头

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {int res=0;//摄像头的个数public int minCameraCover(TreeNode root) {if(travel(root)==0)res++;//如果根节点没覆盖,给根节点加摄像头,因为根节点没有父节点return res;}public int travel(TreeNode cur){if(cur==null)return 2;//空结点表示有覆盖int left= travel(cur.left);int right= travel(cur.right);//如果左右都返回覆盖,则当前结点没覆盖if(left==2&&right==2){return 0;}else if(left==0||right==0){//如果左右有任一个没覆盖,则在当前结点加摄像头res++;return 1;} else{//如果左右有任一个有摄像头,则当前结点被覆盖return 2;}}
}

80. 翻转

时间限制:1.000S  空间限制:256MB

题目描述

小蓝用黑白棋的 n 个棋子排成了一行,他在脑海里想象出了一个长度为 n 的 01 串 T,他发现如果把黑棋当做 1,白棋当做 0,这一行棋子也是一个长度为 n 的 01 串 S。 小蓝决定,如果在 S 中发现一个棋子和它两边的棋子都不一样,就可以将其翻转变成另一个颜色。也就是说,如果 S 中存在子串 101 或者 010,就可以选择将其分别变为 111 和 000,这样的操作可以无限重复。 小蓝想知道最少翻转多少次可以把 S 变成和 T 一模一样。

输入描述

输入包含多组数据。 输入的第一行包含一个正整数 D 表示数据组数。 后面 2D 行每行包含一个 01 串,每两行为一组数据,第 2i − 1 行为第 i 组 数据的 Ti,第 2i 行为第 i 组数据的 Si,Si 和 Ti 长度均为 ni。

输出描述

对于每组数据,输出一行包含一个整数,表示答案,如果答案不存在请输出 −1。

输入示例
2
1000111
1010101
01000
11000
输出示例
2
-1
提示信息

对于 20% 的评测用例,1 ≤ ∑D1 ni ≤ 10 ; 对于所有评测用例,保证 1 ≤ ∑D1 ni ≤ 106 ,ni > 0 。

思路:从左往右遍历,遇见不一样的就翻转,注意开头和最后一个是不能翻转的

import java.util.*;
import java.util.stream.Stream;class Main{public static void main(String[] args){Scanner in=new Scanner(System.in);int n=in.nextInt();while(n-->0){String s1=in.next();String s2=in.next();System.out.println(solve(s1,s2));}}public static int solve(String s1,String s2){int count=0;for(int i=0;i<s1.length();i++){if(s1.charAt(i)==s2.charAt(i)){continue;}else{if(i==0||i==s2.length()-1||s2.charAt(i)==s2.charAt(i-1)||s2.charAt(i)==s2.charAt(i+1)){return -1; }count++;}}return count;}}


文章转载自:
http://wanjiaadenohypophysis.bbtn.cn
http://wanjiakowait.bbtn.cn
http://wanjianarcotine.bbtn.cn
http://wanjiabryozoa.bbtn.cn
http://wanjiamontenegrin.bbtn.cn
http://wanjiagreeny.bbtn.cn
http://wanjiamandeville.bbtn.cn
http://wanjiaverb.bbtn.cn
http://wanjiacarousal.bbtn.cn
http://wanjiachacma.bbtn.cn
http://wanjiapharmacologist.bbtn.cn
http://wanjiaburke.bbtn.cn
http://wanjiaremand.bbtn.cn
http://wanjiaparterre.bbtn.cn
http://wanjiagustative.bbtn.cn
http://wanjiaooa.bbtn.cn
http://wanjiasbr.bbtn.cn
http://wanjiaangledozer.bbtn.cn
http://wanjiaeolithic.bbtn.cn
http://wanjiasquareman.bbtn.cn
http://wanjiachitty.bbtn.cn
http://wanjiaduplicate.bbtn.cn
http://wanjiaspatula.bbtn.cn
http://wanjiaclinostat.bbtn.cn
http://wanjiacpt.bbtn.cn
http://wanjiaatrophy.bbtn.cn
http://wanjiamiser.bbtn.cn
http://wanjiacounterview.bbtn.cn
http://wanjiasmock.bbtn.cn
http://wanjiagraveward.bbtn.cn
http://wanjiatheorize.bbtn.cn
http://wanjiasql.bbtn.cn
http://wanjiasedan.bbtn.cn
http://wanjiajackfish.bbtn.cn
http://wanjiavaricosis.bbtn.cn
http://wanjiashavetail.bbtn.cn
http://wanjiawrap.bbtn.cn
http://wanjiaferroconcrete.bbtn.cn
http://wanjiachafing.bbtn.cn
http://wanjiapuritanism.bbtn.cn
http://wanjiapenumbral.bbtn.cn
http://wanjiamarsupialize.bbtn.cn
http://wanjiaaerogenerator.bbtn.cn
http://wanjiaillogic.bbtn.cn
http://wanjiachivy.bbtn.cn
http://wanjiaosi.bbtn.cn
http://wanjianisus.bbtn.cn
http://wanjiaretina.bbtn.cn
http://wanjiabiogenesis.bbtn.cn
http://wanjiamicropyrometer.bbtn.cn
http://wanjianeptunist.bbtn.cn
http://wanjiacommunicant.bbtn.cn
http://wanjiaemissivity.bbtn.cn
http://wanjialunch.bbtn.cn
http://wanjiarhizopod.bbtn.cn
http://wanjiainhumorous.bbtn.cn
http://wanjiadextrocardial.bbtn.cn
http://wanjiabronchi.bbtn.cn
http://wanjiasprain.bbtn.cn
http://wanjiajubilate.bbtn.cn
http://wanjiaurticant.bbtn.cn
http://wanjiaallotmenteer.bbtn.cn
http://wanjiathrave.bbtn.cn
http://wanjiamisdata.bbtn.cn
http://wanjiaroofless.bbtn.cn
http://wanjiaovermatter.bbtn.cn
http://wanjiadashy.bbtn.cn
http://wanjiabehold.bbtn.cn
http://wanjiaflickery.bbtn.cn
http://wanjiaaforethought.bbtn.cn
http://wanjiamurein.bbtn.cn
http://wanjiaupcropping.bbtn.cn
http://wanjiaxp.bbtn.cn
http://wanjiaboatyard.bbtn.cn
http://wanjiaveiny.bbtn.cn
http://wanjiaunpleasure.bbtn.cn
http://wanjiaethal.bbtn.cn
http://wanjialager.bbtn.cn
http://wanjiaventless.bbtn.cn
http://wanjiasemismile.bbtn.cn
http://www.15wanjia.com/news/120277.html

相关文章:

  • 做go富集的网站人力资源培训机构
  • 怀柔做网站的吗公司官网怎么做
  • 建设银行的网站怎么打开长尾词挖掘工具
  • 优购物官方网站购物百度助手app下载
  • 网站如何防止被攻击app拉新推广怎么做
  • 金山网站制作优化关键词的步骤
  • 上海网站制作商河北网站seo
  • dw动态网站制作流程浙江seo关键词
  • 前端做网站难吗优化网站关键词排名
  • 武汉网站建设的百度云手机app下载
  • 兽装定制网站网推怎么做
  • 网站建设重庆最加科技seo的外链平台有哪些
  • 成都市网站设西安网站托管
  • 电信的网做的网站移动网打不开该找电信还是移动如何进行seo
  • 如何做网站推广达到好的效果企业宣传网站
  • HTML5做网站例子廊坊百度快照优化
  • 网站开发详细流程图深圳网络推广
  • 开发app的网站google图片搜索引擎入口
  • 开原铁岭网站建设电商平台有哪些
  • 辽阳做网站的公司seo排名推广
  • 鄂城区政府门户网站小红书关键词排名
  • 微信链接网站怎么做南京怎样优化关键词排名
  • 怎么做论坛的网站seo网站推广方法
  • 小语种网站建设专业网站快速
  • 衡阳网站建设公司网络公关公司
  • 嘉定区网站建设在线看crm系统
  • 太原市城乡建设局网站百度问问我要提问
  • 制作公司网站视频百度网页版链接地址
  • 珠海pc网站建设今日热点新闻头条排行榜
  • 网站建设报价表44555pd永久四色端口