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

本文共 2594 字,大约阅读时间需要 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/

    你可能感兴趣的文章
    NPM 2FA双重认证的设置方法
    查看>>
    npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
    查看>>
    npm build报错Cannot find module ‘webpack‘解决方法
    查看>>
    npm ERR! ERESOLVE could not resolve报错
    查看>>
    npm ERR! fatal: unable to connect to github.com:
    查看>>
    npm ERR! Unexpected end of JSON input while parsing near '...on":"0.10.3","direc to'
    查看>>
    npm ERR! Unexpected end of JSON input while parsing near ‘...“:“^1.2.0“,“vue-html-‘ npm ERR! A comp
    查看>>
    npm error Missing script: “server“npm errornpm error Did you mean this?npm error npm run serve
    查看>>
    npm error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”。要解决此问题,1) 安装
    查看>>
    npm install CERT_HAS_EXPIRED解决方法
    查看>>
    npm install digital envelope routines::unsupported解决方法
    查看>>
    npm install 卡着不动的解决方法
    查看>>
    npm install 报错 EEXIST File exists 的解决方法
    查看>>
    npm install 报错 ERR_SOCKET_TIMEOUT 的解决方法
    查看>>
    npm install 报错 Failed to connect to github.com port 443 的解决方法
    查看>>
    npm install 报错 fatal: unable to connect to github.com 的解决方法
    查看>>
    npm install 报错 no such file or directory 的解决方法
    查看>>
    npm install 权限问题
    查看>>
    npm install报错,证书验证失败unable to get local issuer certificate
    查看>>
    npm install无法生成node_modules的解决方法
    查看>>