Merge branch 'youngyangyang04:master' into master

This commit is contained in:
YDLIN
2022-01-22 10:15:05 +08:00
committed by GitHub
6 changed files with 77 additions and 9 deletions

View File

@ -186,6 +186,24 @@ var twoSum = function (nums, target) {
}; };
``` ```
TypeScript
```typescript
function twoSum(nums: number[], target: number): number[] {
let helperMap: Map<number, number> = new Map();
let index: number | undefined;
let resArr: number[] = [];
for (let i = 0, length = nums.length; i < length; i++) {
index = helperMap.get(target - nums[i]);
if (index !== undefined) {
resArr = [i, index];
}
helperMap.set(nums[i], i);
}
return resArr;
};
```
php php
```php ```php

View File

@ -142,7 +142,7 @@ class Solution {
Set<Map.Entry<Integer, Integer>> entries = map.entrySet(); Set<Map.Entry<Integer, Integer>> entries = map.entrySet();
// 根据map的value值正序排相当于一个小顶堆 // 根据map的value值正序排相当于一个小顶堆
PriorityQueue<Map.Entry<Integer, Integer>> queue = new PriorityQueue<>((o1, o2) -> o2.getValue() - o1.getValue()); PriorityQueue<Map.Entry<Integer, Integer>> queue = new PriorityQueue<>((o1, o2) -> o1.getValue() - o2.getValue());
for (Map.Entry<Integer, Integer> entry : entries) { for (Map.Entry<Integer, Integer> entry : entries) {
queue.offer(entry); queue.offer(entry);
if (queue.size() > k) { if (queue.size() > k) {

View File

@ -192,8 +192,33 @@ var fourSumCount = function(nums1, nums2, nums3, nums4) {
}; };
``` ```
TypeScript
```typescript
function fourSumCount(nums1: number[], nums2: number[], nums3: number[], nums4: number[]): number {
let helperMap: Map<number, number> = new Map();
let resNum: number = 0;
let tempVal: number | undefined;
for (let i of nums1) {
for (let j of nums2) {
tempVal = helperMap.get(i + j);
helperMap.set(i + j, tempVal ? tempVal + 1 : 1);
}
}
for (let k of nums3) {
for (let l of nums4) {
tempVal = helperMap.get(0 - (k + l));
if (tempVal) {
resNum += tempVal;
}
}
}
return resNum;
};
```
PHP: PHP:
```php ```php
class Solution { class Solution {
/** /**

View File

@ -18,6 +18,8 @@
## 思路 ## 思路
### 动态规划一
本题和[动态规划115.不同的子序列](https://programmercarl.com/0115.不同的子序列.html)相比,其实就是两个字符串都可以删除了,情况虽说复杂一些,但整体思路是不变的。 本题和[动态规划115.不同的子序列](https://programmercarl.com/0115.不同的子序列.html)相比,其实就是两个字符串都可以删除了,情况虽说复杂一些,但整体思路是不变的。
这次是两个字符串可以相互删了,这种题目也知道用动态规划的思路来解,动规五部曲,分析如下: 这次是两个字符串可以相互删了,这种题目也知道用动态规划的思路来解,动规五部曲,分析如下:
@ -98,6 +100,29 @@ public:
``` ```
### 动态规划二
本题和[动态规划1143.最长公共子序列](https://programmercarl.com/1143.最长公共子序列.html)基本相同,只要求出两个字符串的最长公共子序列长度即可,那么除了最长公共子序列之外的字符都是必须删除的,最后用两个字符串的总长度减去两个最长公共子序列的长度就是删除的最少步数。
代码如下:
```CPP
class Solution {
public:
int minDistance(string word1, string word2) {
vector<vector<int>> dp(word1.size()+1, vector<int>(word2.size()+1, 0));
for (int i=1; i<=word1.size(); i++){
for (int j=1; j<=word2.size(); j++){
if (word1[i-1] == word2[j-1]) dp[i][j] = dp[i-1][j-1] + 1;
else dp[i][j] = max(dp[i-1][j], dp[i][j-1]);
}
}
return word1.size()+word2.size()-dp[word1.size()][word2.size()]*2;
}
};
```
## 其他语言版本 ## 其他语言版本

View File

@ -116,19 +116,19 @@ Java
```Java ```Java
// 前序遍历·递归·LC144_二叉树的前序遍历 // 前序遍历·递归·LC144_二叉树的前序遍历
class Solution { class Solution {
ArrayList<Integer> preOrderReverse(TreeNode root) { public List<Integer> preorderTraversal(TreeNode root) {
ArrayList<Integer> result = new ArrayList<Integer>(); List<Integer> result = new ArrayList<Integer>();
preOrder(root, result); preorder(root, result);
return result; return result;
} }
void preOrder(TreeNode root, ArrayList<Integer> result) { public void preorder(TreeNode root, List<Integer> result) {
if (root == null) { if (root == null) {
return; return;
} }
result.add(root.val); // 注意这一句 result.add(root.val);
preOrder(root.left, result); preorder(root.left, result);
preOrder(root.right, result); preorder(root.right, result);
} }
} }
// 中序遍历·递归·LC94_二叉树的中序遍历 // 中序遍历·递归·LC94_二叉树的中序遍历

View File

@ -52,7 +52,7 @@ for(int i = 0; i < weight.size(); i++) { // 遍历物品
```CPP ```CPP
// 先遍历物品,再遍历背包 // 先遍历物品,再遍历背包
for(int i = 0; i < weight.size(); i++) { // 遍历物品 for(int i = 0; i < weight.size(); i++) { // 遍历物品
for(int j = weight[i]; j < bagWeight ; j++) { // 遍历背包容量 for(int j = weight[i]; j <= bagWeight ; j++) { // 遍历背包容量
dp[j] = max(dp[j], dp[j - weight[i]] + value[i]); dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);
} }