算法学习------LeetCode力扣补充篇11

64. 最小路径和
描述
给定一个包含非负整数的 m x n 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。
说明:每次只能向下或者向右移动一步。
示例
示例 1:

输入:grid = \[1,3,1,1,5,1,4,2,1]
输出:7
解释:因为路径 1→3→1→1→1 的总和最小。
示例 2:
输入:grid = \[1,2,3,4,5,6]
输出:12
提示
m == grid.length
n == gridi.length
1 <= m, n <= 200
0 <= gridij <= 200
代码解析
cpp
class Solution {
public:
int minPathSum(vector<vector<int>>& grid) {
int m = grid.size() , n = grid[0].size();
vector<vector<int>> dp(m , vector<int>(n , 0) );
dp[0][0] = grid[0][0];
for(int i=1 ; i<m ;i++)
dp[i][0] = dp[i-1][0] + grid[i][0];
for(int j=1 ; j<n ;j++)
dp[0][j] = dp[0][j-1] + grid[0][j];
for(int i=1 ; i<m ;i++)
{
for(int j=1 ; j<n ; j++)
{
dp[i][j] = min( dp[i-1][j], dp[i][j-1] ) + grid[i][j];
}
}
return dp[m-1][n-1];
}
};
48. 旋转图像
描述
给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。
你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。
示例
示例 1:

输入:matrix = \[1,2,3,4,5,6,7,8,9]
输出:\[7,4,1,8,5,2,9,6,3]
示例 2:

输入:matrix = \[5,1,9,11,2,4,8,10,13,3,6,7,15,14,12,16]
输出:\[15,13,2,5,14,3,4,1,12,6,8,9,16,7,10,11]
提示
n == matrix.length == matrixi.length
1 <= n <= 20
-1000 <= matrixij <= 1000
代码解析
cpp
class Solution {
public:
void rotate(vector<vector<int>>& matrix) {
int m = matrix.size();
int n = matrix[0].size();
for(int i=0 ; i<m ; i++)
{
for(int j=i ; j<n ; j++)
{
swap(matrix[i][j] , matrix[j][i]);
}
}
for(int i=0 ; i<m ; i++)
{
for(int j=0 ; j<n/2 ; j++)
{
swap(matrix[i][j] , matrix[i][n-j-1]);
}
}
}
};
169. 多数元素
描述
给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在多数元素。
示例
示例 1:
输入:nums = 3,2,3
输出:3
示例 2:
输入:nums = 2,2,1,1,1,2,2
输出:2
提示
n == nums.length
1 <= n <= 5 * 104
-109 <= numsi <= 109
进阶:尝试设计时间复杂度为 O(n)、空间复杂度为 O(1) 的算法解决此问题。
代码解析
cpp
class Solution {
public:
int majorityElement(vector<int>& nums) {
map<int,int> my_map;
pair<int,int> result(0,0);
for(int i=0 ; i<nums.size() ; i++)
{
my_map[nums[i]]++;
if(my_map[nums[i]] >= nums.size()/2)
{
if(my_map[nums[i]] > result.second)
{
result.first = nums[i];
result.second = my_map[nums[i]];
}
}
}
return result.first;
}
};
394. 字符串解码
描述
给定一个经过编码的字符串,返回它解码后的字符串。
编码规则为: kencoded_string,表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。
你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。
此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k ,例如不会出现像 3a 或 24 的输入。
示例
示例 1:
输入:s = "3a2bc"
输出:"aaabcbc"
示例 2:
输入:s = "3a2\[c]"
输出:"accaccacc"
示例 3:
输入:s = "2abc3cdef"
输出:"abcabccdcdcdef"
示例 4:
输入:s = "abc3cdxyz"
输出:"abccdcdcdxyz"
提示
1 <= s.length <= 30
s 由小写英文字母、数字和方括号 '\[\]' 组成
s 保证是一个 有效 的输入。
s 中所有整数的取值范围为 1, 300
代码解析
cpp
class Solution {
public:
string decodeString(string s) {
string res;
stack <int> nums;
stack <string> strs;
int num = 0;
for(int i = 0; i < s.size(); i++)
{
if(s[i] >= '0' && s[i] <= '9')
{
num = num * 10 + s[i] - '0';
}
else if(s[i] >= 'a' && s[i] <= 'z')
{
res += s[i];
}
else if(s[i] == '[') //将'['前的数字压入nums栈内, 字母字符串压入strs栈内
{
nums.push(num);
num = 0;
strs.push(res);
res.clear();
}
else //遇到']'时,操作与之相配的'['之间的字符,使用分配律
{
int times = nums.top();
nums.pop();
for(int j = 0; j < times; ++ j)
strs.top() += res;
res = strs.top(); //之后若还是字母,就会直接加到res之后,因为它们是同一级的运算
//若是左括号,res会被压入strs栈,作为上一层的运算
strs.pop();
}
}
return res;
}
};
240. 搜索二维矩阵 II
描述
编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:
每行的元素从左到右升序排列。
每列的元素从上到下升序排列。
示例
示例 1:

输入:matrix = \[1,4,7,11,15,2,5,8,12,19,3,6,9,16,22,10,13,14,17,24,18,21,23,26,30], target = 5
输出:true
示例 2:

输入:matrix = \[1,4,7,11,15,2,5,8,12,19,3,6,9,16,22,10,13,14,17,24,18,21,23,26,30], target = 20
输出:false
提示
m == matrix.length
n == matrixi.length
1 <= n, m <= 300
-109 <= matrixij <= 109
每行的所有元素从左到右升序排列
每列的所有元素从上到下升序排列
-109 <= target <= 109
代码解析
常规
cpp
class Solution {
public:
bool searchMatrix(vector<vector<int>>& matrix, int target) {
int m = matrix.size() , n = matrix[0].size();
int max_point = 1;
for(int i=0 ; i<min(m,n) ;i++)
{
if(matrix[i][i] > target) break;
max_point = i;
}
for(int i=0 ; i < max_point ; i++)
{
for(int j=max_point ; j<n ; j++)
{
if(matrix[i][j] == target) return true;
}
}
for(int i=max_point ; i<m ; i++)
{
for(int j=0 ; j<n ; j++)
{
if(matrix[i][j] == target) return true;
}
}
return false;
}
};
路径优化
cpp
class Solution {
public:
bool searchMatrix(vector<vector<int>>& matrix, int target) {
int m = matrix.size() , n = matrix[0].size();
int x = 0 , y = n-1;
while( x < m && y >= 0)
{
// cout<<matrix[x][y]<<endl;
if(matrix[x][y] == target) return true;
else if(matrix[x][y] > target) y--;
else if(matrix[x][y] < target) x++;
}
return false;
}
};