滴滴出行高级Node.js开发工程师笔试题2024

今天参加了一个滴滴出行的Node.js岗位面试,一面为腾讯视频面试,俩个面试官。面试官比较深入问一些你过去做个的项目,问你解决了哪些棘手的问题。
还有就是他们比较关注性能优化,会问你们现在项目的峰值QPS是多少,如何进行优化等等
最后会在聊天窗口发你两道笔试题,让你在自己本地IDE编写代码调试,但是要开启屏幕共享,方便让他们欣赏你编码的过程。
下面贴一下原题

笔试题1

给定由 a-z A-Z 空格 组成的一个字符串,要求:按字典序输出该字符串中出现的全部字母去重并转化为小写,并给出时间复杂度

例:输入 Hello World,输出 dehlorw

js 复制代码
let str = "Hello World";
let result = str
  .toLowerCase()
  .split("")
  .filter((item) => item !== " ")
  .sort();

console.log([...new Set(result)].join(""));

上面的代码仅供参考,大家可以自行研究性能更高的方式。

笔试题2

给定一个域和一个字符串,若该字符串是一个合法的http/https链接,返回该链接是否在给定域或者其子域下,否则报错退出

例:

输入 didi.com, http://fast.didi.com/foo/bar 返回 true

输入 didi.com, http://fast.uber.com/foo 返回 false

输入 didi.com, fast.didi.com throw Error

你可能也想到使用正则了吧

bash 复制代码
let str = "http://fast.didi.com/foo/bar";
let domain = "didi.com";

function test(domain, str) {
  if (!/^http/.test(str)) {
    throw new Error("str is not a valid url");
  }
  return str.includes(domain);
}

// console.log(test(domain, "http://fast.didi.com/foo/bar"));
// console.log(test(domain, "http://fast.uber.com/foo"));
// console.log(test(domain, "fast.didi.com"));
// console.log(test(domain, "xxhttp://fast.didi.com.cn"));

其实上面的正则还是有问题的,只是可以通过当前给定的测试用例。

更好的方法可以借助javascript的内置对象URL来处理这个问题:

bash 复制代码
function isValidURL(urlString) {
  try {
    new URL(urlString);
    return true; // 如果没有抛出错误,则URL是合法的
  } catch (e) {
    return false; // 如果抛出了错误,则URL不是合法的
  }
}

希望可以帮到你。

相关推荐
Benny的老巢3 小时前
【n8n工作流入门02】macOS安装n8n保姆级教程:Homebrew与npm两种方式详解
macos·npm·node.js·n8n·n8n工作流·homwbrew·n8n安装
2301_818732064 小时前
下载nvm后,通过nvm无法下载node,有文件夹但是为空 全局cmd,查不到node和npm 已解决
前端·npm·node.js
亮子AI5 小时前
【MySQL】node.js 如何判断连接池是否正确连接上了?
数据库·mysql·node.js
a程序小傲5 小时前
【Node】单线程的Node.js为什么可以实现多线程?
java·数据库·后端·面试·node.js
程序员爱钓鱼1 天前
Node.js 编程实战:测试与调试 —— Mocha / Jest / Supertest 使用指南
前端·后端·node.js
冴羽1 天前
JavaScript Date 语法要过时了!以后用这个替代!
前端·javascript·node.js
张洪权1 天前
node fs 模块核心 api
node.js
天远数科1 天前
Node.js全栈实战:构建基于天远多头借贷行业风险版API的BFF风控层
大数据·node.js
_Kayo_1 天前
Node.js 学习笔记6
笔记·学习·node.js
winfredzhang1 天前
[实战] Node.js + DeepSeek 打造智能档案归档系统:从混乱到有序的自动化之旅
css·node.js·js·deepseek api