Twitter算法面试题详解(Java实现)

简介: 最近在网上看到一道Twitter的算法面试题,网上已经有人给出了答案,不过可能有些人没太看明白(我也未验证是否正确),现在给出一个比较好理解的答案。先看一下题目。

最近在网上看到一道Twitter的算法面试题,网上已经有人给出了答案,不过可能有些人没太看明白(我也未验证是否正确),现在给出一个比较好理解的答案。先看一下题目。

图1

先看看这个图。可以将方块看做砖。题干很简单,问最多能放多少水。例如,图2就是图1可放的最多水(蓝色部分),如果将一块砖看做1的话,图2就是能放10个单位的水。


图2

再看个例子

图3

图3可以放17个单位的水。

上面每一个图的砖墙用int数组表示,每一个数组元素表示每一列砖墙的砖数(高度),例如,图3用数组表示就是int[] wallHeights = new int[]{2, 5, 1, 3, 1, 2, 1, 7, 7, 6};

这里某人给出了python的算法点击打开链接,不过有人说有问题,有python环境的可以验证。现在给出我的Java算法。


算法原理

其实很简单,我的算法并不是累加的,而是用的减法,先用图3为例。只需要找到所有墙中最高的,然后再找出第二高的。如果两堵墙紧邻者,就忽略它,否则算一下如果墙之间没有任何其他的砖的情况下可以有多少水(只是一个乘法而已),然后扫描两堵墙之间有多少块砖,减去这个砖数就可以了。最后用递归处理。将两堵墙两侧到各自的左右边界再重新进行前面的操作(递归处理)。直到无墙可处理。 用递归方法很容易理解。下面看一下算法的详细代码。

public class Test
{
    static int result = 0;  //  最终结果
    static int[] wallHeights = new int[]
    {1,6,1,2,3,4,100,1,9};  //  表示所有的墙的高度

    public static void process(int start, int end)
    {
        //  first:start和end之间最高的墙
        //  second:start和end之间第二高的墙
        int first = 0, second = 0;
        //  firstIndex:第一高的墙在wallHeights中的索引
        //  secondIndex:第二高的墙在wallHeights中的索引
        int firstIndex = 0, secondIndex = 0;
        //  两堵墙必须至少有一堵墙的距离
        if (end - start <= 1)
            return;
        //  开始获取第一高和第二高墙的砖数
        for (int i = start; i <= end; i++)
        {
            if (wallHeights[i] > first)
            {
                second = first;
                secondIndex = firstIndex;
                first = wallHeights[i];
                firstIndex = i;
            }
            else if (wallHeights[i] > second)
            {
                second = wallHeights[i];
                secondIndex = i;
            }
        }

        //  获取左侧墙的索引
        int startIndex = Math.min(firstIndex, secondIndex);
        //  获取右侧墙的索引
        int endIndex = Math.max(firstIndex, secondIndex);
        //  计算距离
        int distance = endIndex - startIndex;
        //  如果第一高的墙和第二高的墙之间至少有一堵墙,那么开始计算这两堵墙之间可以放多少个单位的水
        if (distance > 1)
        {
            result = result + (distance - 1) * second;
            //  减去这两堵墙之间的砖数
            for (int i = startIndex + 1; i < endIndex; i++)
            {
                result -= wallHeights[i];
            }
            
        }
        //  开始递归处理左侧墙距离开始位置能放多少水
        process(start, startIndex);
        //  开始递归处理右侧墙距离结束位置能放多少水
        process(endIndex, end);
    }

    public static void main(String[] args)
    {
        process(0, wallHeights.length - 1);
        System.out.println(result);

    }

}
代码中的测试用例的结果是22。下面是几组测试用例。


[ 2 , 5 , 1 , 2 , 3 , 4 , 7 , 7 , 6 ]   结果:10
[ 2 , 5 , 1 , 3 , 1 , 2 , 1 , 7 , 7 , 6 ]  结果:17
[ 6 , 1 , 4 , 6 , 7 , 5 , 1 , 6 , 4 ]   结果:13
[9,6,1,2,3,4,50,1,9]  结果:37

有其他算法的(语言不限)欢迎跟帖


目录
相关文章
|
算法 搜索推荐 Shell
python技术面试题(十五)--算法
python技术面试题(十五)--算法
|
3月前
|
机器学习/深度学习 并行计算 搜索推荐
程序技术好文:桶排序算法及其Java实现
程序技术好文:桶排序算法及其Java实现
27 0
|
存储 Java API
java 一文讲透集合框架(10万字博文)
java API常用工具之集合框架 全面总结,10万字深度讲解。
136 0
java 一文讲透集合框架(10万字博文)
|
4月前
|
自然语言处理 搜索推荐 算法
用Java实现冒泡排序:实用教程带你入门
在处理一些特定系统功能时,经常需要使用冒泡排序。例如,在一个电子商务网站中,需要对商品进行排序和过滤。这个时候可以使用冒泡排序对商品进行排序,以便用户能够按照价格、销量、评分等不同字段进行排序。通过使用冒泡排序,系统可以提供更加灵活和个性化的排序选项,以便用户能够更加方便地找到他们想要的商品。
|
4月前
|
算法 程序员
腾讯T4纯手打《数据结构和算法》源码笔记,学完一脚踢进大厂
经历过互联网公司面试的同学大概都知道,数据结构和算法的知识技术栈是不可避免的,并且在笔试中,最重要的是靠算法题,尤其像头条这种大厂公司,上来就是算法题,答不出来的基本面试机会也不会有了。
|
10月前
|
算法 Java
数据结构与算法中的七大排序(Java实现)
数据结构与算法中的七大排序(Java实现)
60 0
|
设计模式 Dubbo NoSQL
阿里P8面试官不小心泄露的480道万字java面试题和答案
首先给大家介绍阿里面试官的自述: 其实,作为面试官,我对不同级别的候选人,考察的侧重点也有很大的不同。 如果是一个应届生或者是一个有着一年左右工作经验的新人,我会更看里他的基础知识、学习能力和聪明程度,也就是所谓的“潜力”,因为除非候选人非常优秀,否则你很难期望他们进入公司之后迅速独当一面,所以,我更期望通过老员工的少量引导,他再迅速成长为项目的核心成员。
|
安全 Java API
Java高频面试题,谈谈你对OAuth的理解,这道题你会了吗?
1位工作5年的小伙伴被问到这样一道面试题,说谈谈你对OAuth的理解。当时,这位小伙伴感觉回答得不是很理想,希望我拍一期视频详细地介绍一下。 今天,我给大家讲一讲,我对这个问题的理解。
101 0
|
消息中间件 缓存 Java
经过阿里四面而形成的10万字java面试题及答案文档到底有多牛?
首先,给大家介绍一波小伙伴的阿里java岗四面问到的面试题问题分享,大家可以仔细来看看! 一面,问了数据结构、jvm、锁等~
|
Java
通过Java实现双色球原理
通过Java实现双色球原理
187 0