博客
关于我
2021字节跳动算法面试题为什么这么难?上周刚面过算法题已整理成pdf(分享)
阅读量:100 次
发布时间:2019-02-26

本文共 2652 字,大约阅读时间需要 8 分钟。

??????????????

??????????????????????????????????????????????????????????????????????????


????

????????????

???????????????????????????????????prev?current?next??????????

?????

function reverseList(head) {
if (!head || !head.next) return head;
let pre = null;
let current = head;
while (current) {
let next = current.next;
current.next = pre;
pre = current;
current = next;
}
return pre;
}

??????????????????????????next?????????next??pre???pre?????????????????????????pre????????????????????


?????

????????????????????

????????????????????pre-order?????????????????in-order????????????????post-order??????????????

???????????????????????

function kthSmallest(root, k) {
const stack = [];
let result = null;
stack.push(root);
while (stack.length > 0) {
result = stack.pop();
if (result.left) stack.push(result.left);
if (result.right) stack.push(result.right);
}
return result;
}

????

??????????????????????????

  • ???????????1??????1?

    8 & 7 = 0 // 1000 & 0111 ? 0000
  • ???????????1?????1?

    8 | 7 = 15 // 1000 | 0111 ? 1111
  • ?????????????1??????????

    8 ^ 7 = 15 // 1000 ^ 0111 ? 1111
  • ???????????????????????????????

    function sum(a, b) {
    while (a || b) {
    const newA = a ^ b;
    const newB = (a & b) << 1;
    a = newA;
    b = newB;
    }
    return a;
    }

    ???

    ??????????????????????????????????

    ???????

    • ?????????????
    • ??????????? 2*i + 1 ? 2*i + 2????? (i-1)/2?

    ?????

  • ??????????
  • ?????????
  • ???????????????????????
  • ?????

    function heapify(array, index, size) {
    let left = index * 2 + 1;
    while (left < size) {
    let largest = left + 1 < size && array[left] < array[left + 1] ? left + 1 : left;
    if (array[index] < array[largest]) {
    swap(array, index, largest);
    } else {
    break;
    }
    index = largest;
    left = index * 2 + 1;
    }
    }

    ??????

    ???????????????

    ??????????????????????

    function maxDepth(root) {
    if (!root) return 0;
    return Math.max(maxDepth(root.left), maxDepth(root.right)) + 1;
    }

    ????

    ??????????

    ??????????????????????????????????????????

    ?????

    function quickSort(arr, left, right) {
    if (left >= right) return arr;
    let pivot = left;
    let partitionIndex = pivot + 1;
    for (let i = partitionIndex; i < right; i++) {
    if (arr[i] < arr[pivot]) {
    swap(arr, i, partitionIndex);
    partitionIndex++;
    }
    }
    swap(arr, pivot, partitionIndex - 1);
    quickSort(arr, left, partitionIndex - 1);
    quickSort(arr, partitionIndex, right);
    return arr;
    }

    ????????????????????????????????????????????????

    转载地址:http://uoik.baihongyu.com/

    你可能感兴趣的文章
    nginx+tomcat+memcached
    查看>>
    nginx+Tomcat性能监控
    查看>>
    nginx+uwsgi+django
    查看>>
    Nginx-http-flv-module流媒体服务器搭建+模拟推流+flv.js在前端html和Vue中播放HTTP-FLV视频流
    查看>>
    nginx-vts + prometheus 监控nginx
    查看>>
    Nginx下配置codeigniter框架方法
    查看>>
    Nginx之二:nginx.conf简单配置(参数详解)
    查看>>
    Nginx代理websocket配置(解决websocket异常断开连接tcp连接不断问题)
    查看>>
    Nginx代理初探
    查看>>
    nginx代理地图服务--离线部署地图服务(地图数据篇.4)
    查看>>
    Nginx代理外网映射
    查看>>
    Nginx代理模式下 log-format 获取客户端真实IP
    查看>>
    Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
    查看>>
    Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
    查看>>
    Nginx反向代理与正向代理配置
    查看>>
    Nginx反向代理是什么意思?如何配置Nginx反向代理?
    查看>>
    nginx反向代理解决跨域问题,使本地调试更方便
    查看>>
    nginx启动脚本
    查看>>
    Nginx在Windows下载安装启动与配置前后端请求代理
    查看>>
    Nginx多域名,多证书,多服务配置,实用版
    查看>>