• 请不要在回答技术问题时复制粘贴 AI 生成的内容
abusizhishen
V2EX  ›  程序员

面试遇到一道题,没有思路,大家有什么意思

  •  
  •   abusizhishen · Nov 5, 2020 · 1405 views
    This topic created in 2036 days ago, the information mentioned may be changed or developed.
    求字符串中最大的连续整数长度
    如 “11,12,9,8,13,14”
    连续整数为 11,12,13,14,所以长度为 4,要求 o(n)复杂度
    coderluan
        1
    coderluan  
       Nov 5, 2020
    设置一个 bool 数组, 初始为 0, 然后遍历输入数组, 把对应的位数设为 1, 完事之后这个问题就转化成求 bool 数组中最长连续 1, 遍历一遍就有了.
    coderluan
        2
    coderluan  
       Nov 5, 2020
    拿 "2. 4. 3. 6"举例. 生成数组[0,0,0,0,0,0,0], 然后变成[0,1,1,1,0,1,0], 结果就是 3.
    abusizhishen
        3
    abusizhishen  
    OP
       Nov 5, 2020
    @coderluan 明白了,你说的是位图,是一种思路,但是这个数组大小不好设置,另外如果是 1,2,3,100w 这种,位图会非常大
    abusizhishen
        4
    abusizhishen  
    OP
       Nov 5, 2020
    面试官说的是用栈或者堆来实现,但是不能使用排序,我实在想不出来
    coderluan
        5
    coderluan  
       Nov 5, 2020
    @abusizhishen 搜了下,这题 leetcode 原题,翻了下前两页,一般都是 hash 或者排序做的, 没看见堆栈的解法,楼主自己翻翻看吧,题目叫 longest-consecutive-sequence,
    abusizhishen
        6
    abusizhishen  
    OP
       Nov 8, 2020 via iPhone
    @coderluan 看到了,谢谢,
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3237 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 14:05 · PVG 22:05 · LAX 07:05 · JFK 10:05
    ♥ Do have faith in what you're doing.