第四十七天-二叉树,centOS安装tomcat,Maven,vsftpd

今天其实本来有挺多想要感慨的,但是晚上配置环境折腾太久,没有时间了,照这样下去,以后锻炼时间只能改到早上,晚上睡得也比之前晚了,睡眠时间也缩短了,希望能快点结束环境配置。

今日进度:
1.坚持听网课,坚持刷题,虽然二叉树至今为止每一道题都是看了半天题解才弄明白递归逻辑,而且提交完马上就忘记了
2.完成了tomcat的环境配置,配置中途出了问题,又倒回去改昨天jdk的环境配置,但是也因为来回折腾,对Linux里的文件路径有了新的认识
3.坚持早睡,睡太晚反而睡不着了,一定要加快动作
4.坚持锻炼,移到早上去了
5.坚持录小王子,这个只能尽量了

学习笔记:
1.Maven是 Apache 下的一个纯 Java 开发的开源项目。基于项目对象模型(缩写:POM)概念,Maven利用一个中央信息片断能管理一个项目的构建、报告和文档等步骤。Maven 是一个项目管理工具,可以对 Java 项目进行构建、依赖管理。
2.Maven 构建生命周期定义了一个项目构建跟发布的过程。
一个典型的 Maven 构建(build)生命周期是由以下几个阶段的序列组成的:
在这里插入图片描述
在这里插入图片描述
3.Maven 有以下三个标准的生命周期:
clean:项目清理的处理
default(或 build):项目部署的处理
site:项目站点文档创建的处理

4.在 Maven 的术语中,仓库是一个位置(place)。
Maven 仓库是项目中依赖的第三方库,这个库所在的位置叫做仓库。
在 Maven 中,任何一个依赖、插件或者项目构建的输出,都可以称之为构件。
Maven 仓库能帮助我们管理构件(主要是JAR),它就是放置所有JAR文件(WAR,ZIP,POM等等)的地方。
Maven 仓库有三种类型:
本地(local)
中央(central)
远程(remote)

5.Maven 实际上是一个依赖插件执行的框架,每个任务实际上是由插件完成。Maven 插件通常被用来:
创建 jar 文件
创建 war 文件
编译代码文件
代码单元测试
创建工程文档
创建工程报告

6.vsftpd 是“very secure FTP daemon”的缩写,安全性是它的一个最大的特点。vsftpd 是一个 UNIX 类操作系统上运行的服务器的名字,它可以运行在诸如 Linux、BSD、Solaris、 HP-UNIX等系统上面,是一个完全免费的、开放源代码的ftp服务器软件,支持很多其他的 FTP 服务器所不支持的特征。

7.安装tomcat时在bin文件下运行./startup.sh显示Tomcat started,但是浏览器输入http://IP地址:8080无法打开。查询各种网页之后,使用ps -ef|grep tomcat查看进程发现没有,又查了logs文件,发现可能是jdk环境配置不对导致的,运行./shutdown.sh,报错/root/apache-tomcat-7.0.73/bin/catalina.sh: line 467: /usr/share/jdk1.7.0_80/bin/java: 没有那个文件或目录
又在网上各种找资料,找jdk路径

[root@localhost ~]# which java
/usr/bin/java
[root@localhost ~]# ls -lrt /usr/bin/java
lrwxrwxrwx. 1 root root 26 28 22:43 /usr/bin/java -> /usr/java/default/bin/java
[root@localhost ~]# ls -lrt /usr/java/default/bin/java
-rwxr-xr-x. 1 root root 7718 411 2015 /usr/java/default/bin/java

发现实际java路径为/usr/java/default
用vim /etc/profile更改JAVA_HOME的环境配置,source /etc/profile使它生效,再找到安装apache-tomcat-7.0.73的文件下bin文件重新运行./startup.sh,结果报错Cannot find /apache-tomcat-7.0.73/bin/setclasspath.sh,发现CATALINA_HOME的路径又配置错误了,好在用了unset CATALINA_HOME之后,tomcat正常运行,此时打开浏览器,也能正常显示了
在这里插入图片描述
8.235. 二叉搜索树的最近公共祖先
给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。
百度百科中最近公共祖先的定义为:“对于有根树 T 的两个结点 p、q,最近公共祖先表示为一个结点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”

输入: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 8
输出: 6
解释: 节点 2 和节点 8 的最近公共祖先是 6。

解题思路:需要考虑到多种情况,如果p和q都比root小的话,最近公共祖先一定在root的左子树,如果pq都比root大的话,最近公共祖先一定在root的右子树上。其他情况当pq各在一边,p或q为root节点的情况下,root都是最近公共祖先。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */

class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(p.val<root.val && q.val<root.val){
            //当p和q分别在root的两侧时,root为两个节点最近的公共祖先
            return lowestCommonAncestor(root.left, p, q);
        }
        if(p.val>root.val && q.val>root.val){
            return lowestCommonAncestor(root.right, p, q);
        }
        return root;
    }
}

9.98. 验证二叉搜索树
给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。
有效 二叉搜索树定义如下:
节点的左子树只包含 小于 当前节点的数。
节点的右子树只包含 大于 当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。

输入:root = [2,1,3]
输出:true

解题思路:使用递归,设置lower和upper边界,在边界内且左右子树均有效的才是有效节点,左子树时将右边界设为当前节点的值,右子树时将左边界设为当前节点的值。

/**
 * 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 {
    public boolean isValidBST(TreeNode root) {
        return isValidBST(root, Long.MIN_VALUE, Long.MAX_VALUE);
    }
    public boolean isValidBST(TreeNode root, long lower, long upper){
        if(root==null){
            return true;
        }
        if(root.val<=lower || root.val>=upper){
            return false;
        }
        return isValidBST(root.left, lower, root.val) && isValidBST(root.right, root.val, upper);
    }
}

10.108. 将有序数组转换为二叉搜索树
给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。
高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。

输入:nums = [-10,-3,0,5,9]
输出:[0,-3,9,-10,null,5]

解题思路:使用二分法,由于数组是升序排列,中间的节点为root,再在左右递归取中间节点可以保证左右子树高度相差不为1。

class Solution {
    public TreeNode sortedArrayToBST(int[] nums) {
        return helper(nums, 0, nums.length-1);
    }

    public TreeNode helper(int[] nums, int left, int right){
        if(left>right){
            return null;
        }
        int mid = (left+right) / 2;
        TreeNode root = new TreeNode(nums[mid]);
        root.left = helper(nums, left, mid-1);
        root.right = helper(nums, mid+1, right);
        return root;
    }
}

今天太晚了,就不多写了,明天继续加油!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿达斯加

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值