使用VS Code刷LeetCode
一、前言
1.1、说明
本文章用来记录使用VS Code刷LeetCode中遇到的一系列问题。
1.2、原因
-
leetcode 网站中的在线编程环境代码提示、快捷键不友好
-
VS Code中可以通过插件同步Leetcode所有题目,并且在VS Code中进行查看、测试、提交。
-
......
1.2、参考文章
二、具体操作
2.1、VS Code中初始化刷题环境
首先确保已经安装node.js,通过通过如下命令查看安装情况,具体安装过程可以自行搜索,这里推荐使用nvm(nodejs的版本管理工具)去安装和管理node.js和对应的npm(Node.js 的官方包管理工具):nvm下载教程
data:image/s3,"s3://crabby-images/92bb6/92bb671edb5154186087467a77f352dc02b8dafe" alt=""
在VS Code中搜索LeetCode的插件,并安装
data:image/s3,"s3://crabby-images/3e956/3e9560ccda206c7d51f3f239f1ebf7125c4df7a3" alt="外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传"
安装完成后,在VS Code界面的左侧会出现一个LeetCode的图标
data:image/s3,"s3://crabby-images/4d7c2/4d7c2a240235fbc80efe06698ca5ed1c9423dbfd" alt=""
点击Sign in to LeetCode,并选择用LeetCode的账号登录
data:image/s3,"s3://crabby-images/95426/9542674c725d104cd828aa9447a5c60c21c3b7e6" alt=""
输入账号和密码
data:image/s3,"s3://crabby-images/7e83a/7e83af3fe349b5d859622f86438d654cad1a58a3" alt=""
如果提示如下内容,是因为Node14以下版本的NodeJS项目在Node14及以上版本中运行时所抛出的异常
login: (node:40124) Warning: Accessing non-existent property 'padLevels' of module exports inside circular dependency
(Use `node --trace-warnings ...` to show where the warning was created)
pass: - Signing in leetcode.com
[ERROR] session expired, please login again [code=-1]
我们通过nvm切换较低的node版本,nvm相关命令可以参考这篇文章(最下面):https://blog.csdn.net/Bananaaay/article/details/131738477
data:image/s3,"s3://crabby-images/595c3/595c32d149a58820cd28e8baeadb86bcd88b6fe9" alt=""
此时提示的内容是,可以发现不报错了
login: pass: - Signing in leetcode.com
[ERROR] session expired, please login again [code=-1]
我们将leetcode切换到中国版本
data:image/s3,"s3://crabby-images/7ccf8/7ccf889b0c21ea1280598081e8013f40d56fd88a" alt=""
之后再按上面的登录流程,即可登录成功
data:image/s3,"s3://crabby-images/e4815/e48153461bc75a034edd476c6e23afd7ac9e822e" alt=""
此时,我们可以在VS CODE左侧看到刷题的内容
data:image/s3,"s3://crabby-images/c1bdf/c1bdf4a320fe2d9df868ffde769c48c5105d2c62" alt=""
之后就可以开始刷题了
data:image/s3,"s3://crabby-images/db650/db6504ecf137a6403e91fc21ae7cb059181dc63f" alt=""
data:image/s3,"s3://crabby-images/138f4/138f44c3bfcf65377dfd08ef45084be394f54ded" alt=""