剑指Offer——小米+小红书笔试题+知识点总结

情景回顾

  • 时间:2016.9.23 19:00-21:00

    2016.9.24 15:00-17:00
  • 地点:山东省网络环境智能计算技术重点实验室
  • 事件:小米笔试、小红书笔试
  • 注意事项:要有大局观,该舍弃的还是要舍弃,不要在一道编程题上占用超过30分钟的时间。当你思考了15分钟,还没有好的解决方式的时候,毅然舍弃!
    public static void main(String[] args) {
        // 错误声明方式
//      int a [][3];
        // 正确声明方式
        int a [][];
        // 输出 "50.1",字符串拼接
        System.out.println("5" + 0.1);
        // 输出 "0.15",字符串拼接
        System.out.println(0.1 + "5");
}

  构造函数是由jvm创建类实例时自动调用,故其修饰符为private demo(){}

  二分查找的时间复杂度:O(logn)

完全二叉树第一个叶子节点的编号

解法1

深度为6的满二叉树的节点数为 2^6 - 1 = 63;

深度为7的满二叉树的节点数为 2^7 - 1 = 127;

或者根据log2n(往下取整)+1

因此含有100个节点的完全二叉树的深度为7,叶子节点分布在第6层和第7层。

第七层叶子节点数为:100 - 63 = 37;

37 / 2 = 18余1;

因此,第6层的前18个节点是2度节点,第19个节点是1度节点即只有左子树,没有右子树,即第6层前19个节点为非叶子节点,之后为叶子节点。

因此编号最小的叶子节点编号为:2^5 - 1 + 19 + 1 = 51.

其中,2^5 - 1位前5层非叶子节点数(由满二叉树的节点计算公式得出)。

解法2

  根据二叉树性质5:

  • 如果对于一棵有n个节点的完全二叉树(其深度depth=log2n+1下取整)的节点按层序编号(从第一层到第depth层,每层从左到右),对任一节点i(1

    <= i <= n):

    1.如果i=1,则节点i是二叉树的根,无双亲;如果i>1,则其双亲节点是i/2(下取整)。

    2.如果2i>n,则节点i无左孩子(节点i为叶子节点);否则其左孩子是节点2i;

    3.如果2i+1>n,则节点i无右孩子;否则其右孩子节点为2i+1。

  完全二叉树中,对于编号为i的父结点,左孩子编号为2*i,右孩子编号为2*i+1;

  编号为100的节点(为左孩子)对应的父节点编号为50,故最小叶子节点编号为51。

简答题

高可用技术及原理(网络、程序、开源软件)

单例设计模式

// 懒汉式
public class Singleton {
// 延迟加载保证多线程安全
    Private volatile static Singleton singleton;
    private Singleton(){}
    public static Singleton getInstance(){
        if(singleton == null){
            synchronized(Singleton.class){
                if(singleton == null){
                    singleton = new Singleton();
                }
            }
        }
        return singleton;
    }
}

// 饿汉式
class SingletonHungry{
    private final static SingletonHungry singletonHungry = new SingletonHungry();
    private SingletonHungry(){}
    // 务必使用static声明为类所属方法
    public static SingletonHungry getInstance(){
        return singletonHungry;
    }
}

线程与进程的特征及区别

  详见博文《Java进阶(四十四)线程与进程的特征及区别》。

编程题

表达式合法判断(栈的运用)

    public static boolean chkLegal(String A) {
        Stack<Character> stack = new Stack<Character>();
        for(int i = 0; i < A.length(); i++){
            Character ch = A.charAt(i);
            if(ch == '{' || ch == '[' || ch == '('){
                stack.push(ch);
                continue;
            }
            if(!stack.isEmpty()){
                Character c = stack.peek();
                if(ch == '}' && c == '{')
                    stack.pop();
                else if(ch == ']' && c == '[')
                    stack.pop();
                else if(ch == ')' && c == '(')
                    stack.pop();
            }
        }
        if (stack.isEmpty())
            return true;
        return false;
    }




剑指Offer——小米+小红书笔试题+知识点总结的更多相关文章

  1. 剑指Offer——搜狐畅游笔试题+知识点总结

    剑指Offer--搜狐畅游笔试题+知识点总结 情景回顾 时间:2016.9.24 10:00-12:00 地点:山东省网络环境智能计算技术重点实验室 事件:搜狐畅游笔试   注意事项:要有大局观,该舍 ...

  2. 剑指Offer——完美+今日头条笔试题+知识点总结

    剑指Offer--完美+今日头条笔试题+知识点总结 情景回顾 时间:2016.9.28 16:00-18:00 19:00-21:00 地点:山东省网络环境智能计算技术重点实验室 事件:完美世界笔试 ...

  3. 九度 Online Judge 之《剑指 Offer》一书相关题目解答

    前段时间准备华为机试,正好之前看了一遍<剑指 Offer>,就在九度 Online Judge 上刷了书中的题目,使用的语言为 C++:只有3题没做,其他的都做了. 正如 Linus To ...

  4. 《剑指offer(第二版)》面试题60——n个骰子的点数

    一.题目描述 把n个骰子仍在地上,所有的骰子朝上的一面的点数之和为s,输入n,打印出s所有可能的值出现的概率. 二.题解 <剑指offer>上给出的两种方法,尤其是代码,晦涩难懂且没有注释 ...

  5. 结合《剑指offer(第二版)》面试题51来谈谈归并排序

    一.题目大意 给定一个数组A,对于数组A中的两个数字,如果排在前面的一个数字大于(必须大于,等于不算)后面的数字,则这两个数字组成一个逆序对.要求输出数组A中的逆序对的总数.例如,对于数组{7,5,6 ...

  6. 【剑指Offer学习】【面试题:二维数组中的查找】PHP实现

    最近一直看剑指Offer.里面很多算法题.于是就想着用PHP来显示一下. 题目: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序. 请完成一个函数,输入这样的 ...

  7. 《剑指offer(第二版)》面试题64——求1+2+...+n

    一.题目描述 求1+2+3+...+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字以及条件判断语句 (即三元运算符,A? B : C) 二.题解 虽然求和问 ...

  8. 《剑指offer(第二版)》面试题55——判断是否为平衡二叉树

    一.题目大意 输入一颗二叉树,判断该二叉树是否为平衡二叉树(AVL树). 二.题解 <剑指offer>上给出了两种解决方式: 1.第一种是从根节点开始,从上往下遍历每个子节点并计算以子节点 ...

  9. 经典面试题目——找到第n个丑数(参考《剑指offer(第二版)》面试题49)

    一.题目大意 给你一个数n,要求返回第n个丑数.其中,丑数的定义如下: 丑数是指只包含因子2.3和5的数.(数字1也是丑数,不过是个特例)引用<剑指offer>上的话来说,对于一个数M,如 ...

随机推荐

  1. java修改文件内容

    文件的读和写,大家都不陌生,但是修改呢?按照普通的读写流去修改的话,只能全部读取出来,在内存中修改好后,全部写进去,这样对于文件内容过多的时,性能很低. 最近在遇到这个问题的时候,发现RandomAc ...

  2. UVA1349:Optimal Bus Route Design

    题意:给定一个有向带权图,找若干个环,使得每个点属于且仅属于一个环,要求使得环权值之和最小 题解:发现这题中每个点属于且仅属于一个环,这时候"仅"这种恰好的含义,让我们想到了匹配问 ...

  3. [HOJ2634] How to earn more 最大权闭合子图

    Xiao Ming is an expert in computer science and technology, so he can get a lot of projects every mon ...

  4. 修改SQL数据库中表字段类型时,报“一个或多个对象访问此列”错误的解决方法

    在SQL数据库中使用SQL语句(格式:alter table [tablename] alter column [colname] [newDataType])修改某表的字段类型时,报一下错误:由于一 ...

  5. 以太坊区块链Java(EthereumJ)学习笔记:概述

    本系列文章介绍以太坊区块链基于Java语言的解决方案.通过介绍EthereumJ定义的主要模块和Class,希望为大家学习和使用EthereumJ提供一些帮助. 整体架构 以太坊的Java解决方案主要 ...

  6. mysql获取某个表的所有字段名

    http://www.netingcn.com/mysql-column-name.html mysql安装成功后可以看到已经存在mysql.information_schema和test这个几个数据 ...

  7. asp.net用户控件引用

    <%@ Register Src="~/_module/IndexChannelHead.ascx" TagName="tn" TagPrefix=&qu ...

  8. linux上安装fastdfs+nginx+ngin-module实践并解决多个异常篇

    为什么选择Nginx Nginx 是一个很牛的高性能Web和反向代理服务器, 它具有有很多非常优越的特性: 在高连接并发的情况下,Nginx是Apache服务器不错的替代品:Nginx在美国是做虚拟主 ...

  9. WPF TextBlock 判断 isTextTrimmed 文本是否超出

    WPF TextBlock 设置TextTrimming情况下 判断 isTextTrimmed(Text 文本是否超出 是否出现了省略号) private bool HasTextTrimmed(T ...

  10. sql server 的osql 使用例子

    一次性执行一个语句并输出到文件: osql -Usa -dSCGWYDJ2012 -P -S192.168.56.1 -Q "exit( SELECT top 1 * FROM A08)&q ...