README
背景和开发过程见此博文
LeetCode TypeScript 解题工具
特性
- 针对
leetcode-cn.com
开发 - 提供
TypeScript
工程模版,支持自定义 - 使用本地测试数据
- 支持同一个问题的多个解答,可随时切换
运行需求
- Node.js v10+
- Google Chrome
- 仅在Mac OSX下测试过
安装
$ npm i -g ts-leetcode
初始化工程
由leetcode-ts-template模版创建工程并clone到本地
在工程根目录运行以下命令:
$ npm i
$ mv .tslcrc.example .tslcrc
根据需要调整
.tslcrc
中browserPath
的值为Google Chrome浏览器路径登录(用户名和密码会被直接发送到leetcode网站,不会被保存到本地或其他地方):
$ tslc login
✔ Username: · xxxxxxxx
✔ Password: · ********
Logging in, this may take some time...
Success!
解题步骤
- 创建解答目录
$ tslc init invert-binary-tree
需提供题目的短标题作为参数。例如题目的url为https://leetcode-cn.com/problems/invert-binary-tree/
,则题目的短标题为url路径的最后一部分invert-binary-tree
若第一次运行,此命令会创建如下目录结构:
questions/invert-binary-tree
├── input
├── solution.ts -> solution1.ts
├── solution1.ts
└── tsconfig.json
编辑
input
中的测试数据编辑
solution.ts
中的代码编译
$ tslc build
Hash: f5834e34f10e512f08a5
Version: webpack 4.44.1
Time: 1235ms
Built at: 2020-08-15 11:46:53 AM
Asset Size Chunks Chunk Names
solution.js 7.03 KiB 0 [emitted] main
Entrypoint main = solution.js
[0] ./questions/invert-binary-tree/solution1.ts 868 bytes {0} [built]
- 测试
$ tslc test
STARTED
STARTED
SUCCESS
- 提交
$ tslc submit
STARTED
Accepted
Runtime: 84 ms, 32.27%
Memory: 40 MB, 5.12%
.tslcrc
配置browserPath
: Google Chrome浏览器路径mode
: webpack mode
备注
tslc init
可以被多次运行,每次运行会新增一个解答文件- 新文件按照
solution2.ts
,solution3.ts
的顺序命名 solution.ts
是指向最新解答文件的软链接,是后续构建测试和提交的输入文件tslc select <n> [questionSlug]
会将软链接指向solution<n>.ts
- 新文件按照
- 如果未向命令行提供题目短标题,则会使用最近一次命令中使用过的短标题