zoukankan      html  css  js  c++  java
  • 算法和数据结构总览

    算法和数据结构总览

    如何精通一个领域

    1. Chunk it up 切碎知识点
    • 庖丁解牛
    • 脉络连接

    数据结构

    • 一维
      • 基础:数组array(string),链表linked list
      • 高级:栈stack,队列queue,双端队列deque,集合set,映射map(hash or map),……
    • 二维:
      • 基础:树tree,图graph
      • 高级:二叉搜索树binary search tree(red-black tree,AVL),堆heap,并查集disjoint set,字典树Trie,……
    • 特殊:
      • 位运算Bitwise,布隆过滤器BloomFiter
      • LRU Cache
        注意:了解每个数据结构的原理和代码框架
        数据结构脑图

    算法

    • if-else,switch——>branch(分支)
    • for,while loop——>iteration(循环,迭代)
    • 递归Recursion(Divide & Conquer,Backtrace)
    • 搜索Search:深度优先搜索Depth first search(DFS),广度优先搜索Breadth first search(BFS),A*,……
    • 动态规划Dynamic Programming
    • 二分查找Binary Search
    • 贪心Greedy
    • 数学Math,几何Geometry
      注意:在头脑中会议上面每种算法的思想和代码模板
      算法脑图
    1. Deliberate Practicing刻意练习

    职业化运动

    • 基本功是区别业余和职业选手的根本
    • 基础动作的分解训练和反复练习->最关键的点
      • 乒乓球
      • 台球
      • 滑雪

    练习的方法

    • 刻意练习——过遍数
    • 练习缺点、弱点地方
    • 不舒服、不爽、枯燥
    • 生活中例子:乒乓球、台球、游戏等等
    1. Feedback 反馈

    Feedback

    • 即时反馈
    • 主动型反馈(自己去寻找)
      • 看高手写代码(GitHub,LeetCode,……)
      • 第一视角直播
    • 被动式反馈(高手给你指点)
      • code review
      • 教练看你打,给你反馈

    切题四件套

    • Clarification(说明问题的解法)
    • Possible solutions(找到可以解决的方法)
      • compare(time/space)(比较时间复杂度和空间复杂度)
      • optimal(加强)(找到最佳的解法)
    • Coding(多写)
    • Test cases(举出测试用例)

    五步刷题法

    刷题第一遍

    • 5分钟:读题+思考
    • 直接看解法:注意!多解法,比较解法优劣
    • 背诵,默写好的解法

    刷题第二遍

    • 马上自己写——>LeetCode提交
    • 多种解法比较、体会->优化

    刷题第三遍

    • 过了一天后,再重复做题
    • 不同解法的熟练程度——>专项练习

    刷题第四遍

    • 过了一周,反复回来练习相同题目

    刷题第五遍

    • 面试前一周恢复性训练
  • 相关阅读:
    可视化工具Navicat 视图 事物 存储过程
    mysql用户管理 + pymysql的使用
    0914 表与表之间的关系补充一对一关系 记录操作 关键字 多对多 子查询
    0913数据库约束之主键 外键 非空 默认值约束 唯一约束 级联操作 表与表之间的联系
    数据库的数据类型
    面向对象之继承
    面向对象
    re模块
    加密常用模块
    日志模块
  • 原文地址:https://www.cnblogs.com/liugangjiayou/p/12368789.html
Copyright © 2011-2022 走看看