面经

链接:[https://www.nowcoder.com/discuss/35473]
首先进行一个小时的笔试。一面的主要内容就是讨论笔试题,然后聊了一些简历上的东西。面试官人很和蔼,沟通起来不累。笔试题如下:

1、有一个数组包含1000w个整数,给定一个整数n,在数组中找到所有ai和bi,使得ai+bi=n,写出代码。

首先想到了暴力法,时间复杂度是O(n^2),然后使用了一个桶排序优化暴力。其实能不能优化心里也不清楚,感觉可以就写上了。

补充:感谢 @zssasa
Two Sum问题:[http://blog.csdn.net/u010429424/article/details/77648989]

public int[] twoSum(int[] numbers,int target){
    HashMap<Integer,Integer> map=new HashMap<>();
    int[] res=new int[2];
    for (int i = 0; i <numbers.length ; i++) {
        if(map.containsKey(numbers[i])){
            res[0]=map.get(numbers[i])+1;
            res[1]=i+1;
            break;
        }else {
            map.put(target-numbers[i],i);
        }
    }
    return res;
}

2、二叉树,找到两个节点的最近公共父节点,写出代码。

由于题目没有给出二叉树的输入形式,因此根据以往的做题经验,如果二叉树以数组的形式给出,则直接用公式就能计算出父节点。比如二叉树【1,2,3,4,5】,则4、5的父节点下标为(3-1)/2 = 1和(4-1)/2 = 1。


20170828123905634.jpg

如果二叉树以树的形式给出,分两种情况考虑,如果二叉树节点中有指向父节点的指针,则可以通过这个指针很方便地找到公共父节点。如果二叉树中没有指向父节点的指针,则先通过dfs找到根节点到4、5节点的路径:1、2、4和1、2、5,路径使用链表存储,然后从4、5向前找到第一次出现的公共节点。

但是面试官说,通过遍历树会有更好的方法。

补充:通过后续遍历,可以解决这个问题:https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-tree/discuss/

public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;
    TreeNode(int x) {
        val = x;
    }
}

public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
    if (root == p || root == q || root == null)
        return root;
    TreeNode left = lowestCommonAncestor(root.left, p, q);
    TreeNode right = lowestCommonAncestor(root.right, p, q);
    if (left == null) {
        return right;
    } else if (right == null) {
        return left;
    } else {
        return root;
    }
}

3、一个袋中有n个球,球上面有标号,标号可以相同也可以不同。如果袋中球的编号之和大于编号之积,则叫做幸运袋,反之就是不幸运的。比如【1、3】1+3 > 1* 3就是幸运的;【2、3】,2+3 < 2 * 3就是不幸运的。现在给出一个有n个球的袋子,可以去掉m个球使得剩余的球构成幸运袋,问能够成的幸运袋的个数,写出代码。

深度优先遍历

public class YiQiu {
    public static  int getNum(int[] a,int start,long sum,long multi){
        int res=0;
        for (int i = start; i <a.length ; i++) {
            sum+=a[i];
            multi*=a[i];
            if(sum>multi){
                res+=1+getNum(a,i+1,sum,multi);
            }
            else if(a[i]==1){
                res+=getNum(a,i+1,sum,multi);
            }
            else {
                break;
            }
            sum=sum-a[i];
            multi=multi/a[i];
            for (; (i < (a.length-1))&&(a[i]==a[i+1]); i++) ;

        }
        return  res;
    }

    public static void main(String[] args) {
        int[] a={1,1,2,3};
        System.out.println(getNum(a,0,0,0));
    }
}

4、通过IP怎么查找到城市。给出一组IP地址和对应的城市名,问使用怎样的数据结构,能够找到城市,写出代码。

第一个思路使用Trie树来存储IP,叶子节点对应城市。但看到题目的函数输入是整型的ip,瞬间感觉也可以用Hash来做,key是ip,value是对应的城市。因为不知道怎样把ip转换成int,被面试官鄙视了。。。。(当时说ip本质上也是用二进制来表示的,因此可以通过位运算转换成int)

补充:Ip转long http://www.mkyong.com/java/java-convert-ip-address-to-decimal-number/

public long ipToLong(String ipAddress){
    String[] ipAddressArray=ipAddress.split("\\.");
    long res=0;
    for (int i = 0; i <ipAddressArray.length ; i++) {
        int power=3-i;
        int ip=Integer.parseInt(ipAddressArray[i]);

        res += ip*Math.pow(256,power);
    }
    return res;
}

5、编辑器的undo撤销,redo恢复怎样实现,写出代码。

看到这道题的第一反应就是Git。但是不懂git的数据结构,只能装模作样地设计了一个双向链表。这样,通过指针的改变就能很快地前移和后退。结构又被面试官鄙视了~
(补充:后来听同学讲可以用两个栈来实现,
参考:
http://blog.csdn.net/cb0912cn/article/details/444393

一 定义栈结构
Public Type stack
Num As Integer '记录栈的大小
contents As String '记录内容
Pos As Long '记录光标位置
End Type
分别需要两个栈,一个栈stackundo来存放撤消内容,一个栈stackredo来存放恢复内容
二 在文本内容改变的同时,将文本内容,以及此时光标位置存入栈stackundo中。
三 进行undo操作后,把undo前的内容和光标位置存入栈stackredo中,同时在栈stackundo中清除该内容。
四 进行redo操作后,把redo前的内容和光标位置存入栈stackundo中,同时在栈stackredo中清除该内容。
通过上述过程就能很简单的实现无限次undo和redo操作。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容

  • 从15年毕业到北京以来一直住在北京昌平这边,由于离清河比较近,因此来过几次五彩城这边,而这也是小米的总部,一个曾经...
    克洛诺斯阅读 1,376评论 1 6
  • 写了个显眼的标题,就真得说几句有用的话。 5月份一个很偶然的机会,加了叶神的微信,还收到了祝福。一激动就承诺说写篇...
    XiaoTeng阅读 9,644评论 6 57
  • 给你一个多叉树。移出所有子树,当这个子树的全部节点的值的和为0。 struct TreeNode { vector...
    Ammahu阅读 231评论 0 0
  • 远程登录另一台机器 SSH 原理与运用 用密码登录ssh user@host 密码:user(如ssh stude...
    马建阳阅读 262评论 0 0
  • 很开心,在简书写的第一篇文字得到喜欢,也许无意,也许有心,无论怎样,都好,谢谢那个不曾谋面的人。我会写下去...
    沈安乐阅读 1,112评论 0 0