数据结构算法 - LeetCode 刷题

数据结构和算法的课程讲解,目前已告一段落,也算是完成了自己的一个心愿。因为去年听某同学抱怨过,说自己去爱奇艺面试,其他问题都答得不错,面试官问了一个哈夫曼算法的题没答出来,后来面试官很明确的说,我们还是想找一个会些算法基础的。

如果之前有学过数据结构和算法,建议大家不定时的去刷刷算法题,因为从面试的角度来讲,目前 BAT 和 TMD 等一线互联网企业或多或少都会有几个算法题,而对应届毕业生来说算法的要求度则更高。当然大家面试过程中遇到的算法题,90%都来自于各大刷题网站。另一方面从开发的角度来讲,数据结构和算法绝对是一门内功,思维方式和严谨程度上都会有一个跳跃性的提升。就在前几天团队出现了两个疑难杂症,一个是小米手机的 View 数据丢失的 Bug,一个是直播间高斯模糊算法的卡顿。解决问题时若我们能站在底层源码和算法的角度去分析问题,绝对会要轻松许多。

在线编程评测的平台有很多,比较有名的有 Hihocoder,LintCode,LeetCode。我们一般在 LeetCode 上刷题比较多,目前有九百多道题目。不必每道题都刷,但建议至少把前 200 道刷一遍。不要看标签,不要看标签,标签相当于问题的分类,看了标签就会往那个方向去想,不利于自主思考。如果目前正处于面试阶段建议每天刷两三题,如果目前是工作状态可以不定时的刷一刷。LeetCode 的题型都非常简单明了,并不需要复杂的理解,一般都在几十行以内就可以解决了,如果你写了上百行代码,就肯定说明你想太多了或太复杂,虽然都能用很短的代码就能解决,但并不意味着 LeetCode 的题目非常简单,实际上LeetCode 基本上涉及到了所有常规的算法类型。

独立解决一个问题是最好的学习途径。如果你被某一个地方卡住了,不要急着去网上找答案,不管代码写得有多么烂先想办法实现,然后再想想有没有更好的方案,最后再去参考参考他人的实现方式。切记不是为了简单的实现,而是去想有没有更好的解决方案。请看第一题:

1. Two Sum

Given an array of integers, return indices of the two numbers such that they add up to a specific target.

You may assume that each input would have exactly one solution, and you may not use the same element twice.

Example:

  Given nums = [2, 7, 11, 15], target = 9,
  Because nums[0] + nums[1] = 2 + 7 = 9,

  return [0, 1].

这道题从通过率来看已经比较高了,题目本身也非常简单,用暴力破解即可:

  public int[] twoSum(int[] nums, int target) {
    for(int i=0;i<nums.length;i++){
      for(int j= i + 1;j<nums.length;j++){
        if(nums[i]+nums[j] == target){
          return new int[]{i,j};
        }
      }
    }
    return null;
  }

单从结果上来看是通过了,但切记不是为了简单的实现,而是去想有没有更好的解决方案。就好比现在有一个棘手的问题摆在咋们面前,我们的追求只是简单去实现,还是应该想想有没有更好的解决方案呢?再想想:

  public int[] twoSum(int[] nums, int target) {
    Map<Integer,Integer> maps = new HashMap<>(nums.length);
    for(int i=0;i<nums.length;i++){
      int diff = target - nums[i];
      if(maps.containsKey(diff)){
        return new int[]{maps.get(diff),i};
      }
      maps.put(nums[i],i);
    }
    return null;
  }

从上面来看,该题算法的复杂度可以优化到 O(n) ,那为何测试结果却显示未达最优?我们之前分析 HashMap 的源码时,可知其查找算法的复杂度,最好的情况是 O(1) 最坏是 O(logN) 。因此我们还可以有更好的解决方案:

  public int[] twoSum(int[] nums, int target) {
    Integer[] filter = new Integer[4096];
    int length = nums.length;
    int diff = 0;
    for(int i=0;i<length;i++){
      diff = target - nums[i];
      Integer index = filter[diff&4095];
      if(index != null){
        return new int[]{index,i};
      }
      filter[nums[i]&4095] = i;
    }
    return null;
  }


8. String to Integer (atoi)

Implement atoi which converts a string to an integer.

The function first discards as many whitespace characters as necessary until the first non-whitespace character is found. Then, starting from this character, takes an optional initial plus or minus sign followed by as many numerical digits as possible, and interprets them as a numerical value.

The string can contain additional characters after those that form the integral number, which are ignored and have no effect on the behavior of this function.

If the first sequence of non-whitespace characters in str is not a valid integral number, or if no such sequence exists because either str is empty or it contains only whitespace characters, no conversion is performed.

If no valid conversion could be performed, a zero value is returned.

Note:

  • Only the space character ' ' is considered as whitespace character.
  • Assume we are dealing with an environment which could only store integers within the 32-bit signed integer range: [−231, 231 − 1]. If the numerical value is out of the range of representable values, INT_MAX (231 − 1) or INT_MIN (−231) is returned.

这题也是鹅厂面试题中的一道高频算法题,题目本身并不难,但从通过率上来看却是一道极低的题目,主要考察的是我们思考问题的时候是否严谨。好比我们在公司完成了一个需求,测试没问题,灰度也没问题,但上线就出现问题了。某部分原因也是我们在做需求的时候很多场景没有考虑到,在公司老大最喜欢说的口头禅之一就是 “你这样写有坑”。

  int myAtoi(string str) {
    long result = 0;
    int len = str.length();
    int index = 0;
    // 过滤空格
    while(index<len && str[index] == ' '){ 
      index++;
    }
        
    // 正负符号
    int negative = 1;     
    if(index<len && str[index] == '+'){
      index++;
    }
    else if(index<len && str[index] == '-'){
      negative = -1;
      index++;
    }
        
    if(index == len){
      return 0;
    }
        
    // 计算结果
    while(index<len){
      char c = str[index++];
            
      if(c<'0' || c>'9'){
        break;
      }
            
      result = result*10 + (c-'0');
      // 处理越界的情况
      if(negative*result > INT_MAX)
        return INT_MAX;
      else if(negative*result < INT_MIN)
        return INT_MIN;
    }  
    return result*negative;
  }

视频链接:https://pan.baidu.com/s/1onpWrPBrS3cvnMmc9FzJhQ
视频密码:txq8

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