/**
* 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;
* }
* }
*/classSolution{int max;publicintlongestUnivaluePath(TreeNode root){
max =0;dfs(root);return max;}publicintdfs(TreeNode root){if(root ==null)return0;//以每一个结点为根int left =dfs(root.left);//获取左子树的相同结点路径长度int right =dfs(root.right);int _left =0, _right =0;//记录路径长度//如果左或右子树和当前结点相同,记录连接左右子树分别的路径长度if(root.left !=null&& root.left.val == root.val) _left = left+1;if(root.right !=null&& root.right.val == root.val) _right = right+1;//max中保存和当前结点相连后的路径长度,保存大的
max =Math.max(max,_left+_right);returnMath.max(_left,_right);//返回时,返回和左右子树相连后,较长的路径}}
2. 深度优先,用父结点判断
解题思路:时间复杂度O(n),空间复杂度O(n)
一个细节的改变,可以省下一些判断
每次深度优先遍历时,传入当前结点的值(下一个结点的父结点)
如果当前结点和父结点值相同,就返回较长路径长度
不断记录相连后的最大路径
代码
classSolution{int max =0;publicintlongestUnivaluePath(TreeNode root){dfs(root,-1);return max;}//root是当前结点,parentVal是父结点的值publicintdfs(TreeNode root,int parentVal){if(root ==null)return0;//如果root == null 说明没有路径int left =dfs(root.left,root.val);//获取左子树的和当前结点值相同的连续路径长度int right =dfs(root.right,root.val);
max =Math.max(max,left+right);//保存左右子树和当前结点相连后的路径长度,保存大的//如果当前结点和父结点相同,返回较长路径+1,其中+1是加上自己本身后的路径长度,因为left和right是不加他自己的路径长度if(root.val == parentVal)returnMath.max(left,right)+1;return0;//返回时,返回和左右子树相连后,较长的路径}}
Texture sampling is only supported on the GPU at the moment.(纹理采样目前仅在GPU上受支持)
效果:textures can be referenced within GPU particle systems。this demo maps a texture to a grid of particles(纹理可以在GPU粒子系统中被引用这个演…
BetterDisplay Pro是一款由waydabber开发的Mac平台上的显示器校准软件,可以帮助用户调整显示器的颜色和亮度,以获得更加真实、清晰和舒适的视觉体验。 软件下载:BetterDisplay Pro for Mac v2.0.11激活版下载 🔍 精准校准…
获取位置服务总开关状态
//获取LOCATION_MODE值,但adb状态下无法获取
//0为关闭,1 gps、2 network、3 高精度等
int state Settings.Secure.getInt(mContext.getContentResolver(),Settings.Secure.LOCATION_MODE,Settings.Secure.LOCATION_MODE_HIGH_…