-
Notifications
You must be signed in to change notification settings - Fork 19
Expand file tree
/
Copy pathmongo-init.js
More file actions
92 lines (90 loc) · 6.47 KB
/
mongo-init.js
File metadata and controls
92 lines (90 loc) · 6.47 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
// mongo-init.js (MongoDB Shell 语法)
db = db.getSiblingDB('online'); // 确定数据库名称为 'online'
const initQuestions = [
{
docName: '两数之和',
desc: '# 问题描述\n\n给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。\n\n你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。\n\n## 示例\n```python\nInput: nums = [2, 7, 11, 15], target = 9\nOutput: [0, 1]\n```',
},
{
docName: '两数相减',
desc: '# 问题描述\n\n给定两个非负整数 num1 和 num2 表示两个数,计算这两个数的差(num1 - num2),不得使用 * / % + - 等运算符。\n\n## 示例\n```python\nInput: num1 = 10, num2 = 3\nOutput: 7\n```',
},
{
docName: '两数相乘',
desc: '# 问题描述\n\n给定两个非负整数 num1 和 num2 表示两个数,计算这两个数的乘积,不得使用 * / % + - 等运算符。\n\n## 示例\n```python\nInput: num1 = 3, num2 = 7\nOutput: 21\n```',
},
{
docName: '两数相除',
desc: '# 问题描述\n\n给定两个整数,被除数 dividend 和除数 divisor。将两数相除,要求不使用乘法、除法和 mod 运算符。\n\n返回被除数 dividend 除以除数 divisor 得到的商。\n\n## 示例\n```python\nInput: dividend = 10, divisor = 3\nOutput: 3\n```',
},
{
docName: '字符串反转',
desc: '# 问题描述\n\n编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 char[] 的形式给出。\n\n不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。\n\n## 示例\n```python\nInput: ["h","e","l","l","o"]\nOutput: ["o","l","l","e","h"]\n```',
},
{
docName: '回文检测',
desc: '# 问题描述\n\n判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。\n\n## 示例\n```python\nInput: 121\nOutput: true\n```',
},
{
docName: '数组去重',
desc: '# 问题描述\n\n给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。\n\n不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。\n\n## 示例\n```python\nInput: nums = [1,1,2]\nOutput: 2, nums = [1,2]\n```',
},
{
docName: '数组排序',
desc: '# 问题描述\n\n给定一个整数数组 nums,原地对它们进行排序。可以使用任何一种排序算法。\n\n## 示例\n```python\nInput: nums = [5, 2, 3, 1]\nOutput: [1, 2, 3, 5]\n```',
},
{
docName: '链表反转',
desc: '# 问题描述\n\n反转一个单链表。\n\n## 示例\n```python\nInput: 1->2->3->4->5->NULL\nOutput: 5->4->3->2->1->NULL\n```',
},
{
docName: '二叉树遍历',
desc: '# 问题描述\n\n给定一个二叉树,返回其节点值的前序/中序/后序遍历。\n\n## 示例\n```python\nInput: [1,null,2,3]\nOutput: [1,2,3] (Preorder)\nOutput: [1,3,2] (Inorder)\nOutput: [3,2,1] (Postorder)\n```',
},
{
docName: '最长公共前缀',
desc: '# 问题描述\n\n编写一个函数来查找字符串数组中的最长公共前缀。\n\n如果不存在公共前缀,返回空字符串 ""。\n\n## 示例\n```python\nInput: ["flower","flow","flight"]\nOutput: "fl"\n```',
},
{
docName: '最小公倍数',
desc: '# 问题描述\n\n给定两个正整数,计算它们的最小公倍数。\n\n## 示例\n```python\nInput: a = 4, b = 6\nOutput: 12\n```',
},
{
docName: '最大公约数',
desc: '# 问题描述\n\n给定两个正整数,计算它们的最大公约数。\n\n## 示例\n```python\nInput: a = 4, b = 6\nOutput: 2\n```',
},
{
docName: '斐波那契数列',
desc: '# 问题描述\n\n给定 n,计算斐波那契数列的第 n 项。斐波那契数列定义如下:F(0) = 0, F(1) = 1, F(n) = F(n - 1) + F(n - 2) (n >= 2)。\n\n## 示例\n```python\nInput: 4\nOutput: 3\n```',
},
{
docName: '汉诺塔问题',
desc: '# 问题描述\n\n汉诺塔是一个经典的数学问题,通常用递归来解决。给定三个柱子 A, B, C 和 n 个不同大小的盘子,盘子初始全部位于 A 柱上。每次只能移动一个盘子,且大盘子不能放在小盘子上面。目标是将所有盘子从 A 柱移动到 C 柱。\n\n## 示例\n```python\nInput: n = 3\nOutput: ["A -> B", "A -> C", "B -> C"]\n```',
},
{
docName: '八皇后问题',
desc: '# 问题描述\n\n八皇后问题是将八个皇后放置在国际象棋棋盘上,使得任何一个皇后都无法直接吃掉其他的皇后。为了达到此目的,任两个皇后都不能处于同一条横行、纵行或斜线上。\n\n## 示例\n```python\nInput: 8\nOutput: [[".Q..","...Q","Q...","..Q."],["..Q.","Q...","...Q",".Q.."]]\n```',
},
{
docName: '背包问题',
desc: '# 问题描述\n\n给定不同面额的硬币 coins 和一个总金额 amount。编写一个函数来计算可以凑成总金额所需的最少的硬币个数。如果没有任何一种硬币组合能组成总金额,返回 -1。\n\n## 示例\n```python\nInput: coins = [1, 2, 5], amount = 11\nOutput: 3\n```',
},
{
docName: '最短路径',
desc: '# 问题描述\n\n给定一个加权有向图和一个起点 s,找到从 s 到其他每个顶点的最短路径。图中可能存在负权重边,但保证不存在负权重环。\n\n## 示例\n```python\nInput: graph = [[0, 4, 0, 0, 0, 0, 0, 8, 0], [4, 0, 8, 0, 0, 0, 0, 11, 0], ...], start = 0\nOutput: [0, 4, 12, ...]\n```',
},
{
docName: '图的遍历',
desc: '# 问题描述\n\n给定一个无向图,实现深度优先搜索(DFS)和广度优先搜索(BFS)遍历。\n\n## 示例\n```python\nInput: graph = [[1, 2], [0, 2], [0, 1, 3], [2]], start = 0\nOutput: DFS: [0, 1, 2, 3], BFS: [0, 1, 2, 3]\n```',
},
{
docName: '动态规划',
desc: '# 问题描述\n\n动态规划是一种通过把原问题分解为相互重叠的子问题来求解复杂问题的方法。编写一个函数来解决一个特定的问题,比如找零钱问题、最长递增子序列等。\n\n## 示例\n```python\nInput: coins = [1, 2, 5], amount = 11\nOutput: 3\n```',
},
];
if (db.code_questions.countDocuments() === 0) {
db.code_questions.insertMany(initQuestions);
print('Inserted default documents');
} else {
print('Database already initialized');
}