1.最长回文子串
![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/52a1ed59100c5a3d7324d1023c8d55cc.png)
class Solution {
public:
string longestPalindrome(string s) {
int len = s.length();
if(len==0 || len==1) return s;
vector<vector<bool>> dp(len,vector<bool>(len,false));
for(int i=0;i<len;i++){
dp[i][i] = true;
}
int maxLen = 1;
int begin = 0;
for(int L=2;L<=len;L++){
for(int i=0;i<len;i++){
int j = i+L-1;
if(j>=len) break;
if(s[j]!=s[i]) dp[i][j]=false;
else{
if(j-i==1) dp[i][j]=true;
else dp[i][j] = dp[i+1][j-1];
}
if(dp[i][j] && L>maxLen){
maxLen = L;
begin = i;
}
}
}
return s.substr(begin,maxLen);
}
};
2.括号生成(回溯)
![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/201975ced166b8387686de114f65ce77.png)
class Solution {
public:
void backtrack(vector<string>& res,string cur,int open,int close,int n){
if(cur.length()==n*2){
res.push_back(cur);
return;
}
if(open<n){
cur.push_back('(');
backtrack(res,cur,open+1,close,n);
cur.pop_back();
}
if(close<n && close<open){
cur.push_back(')');
backtrack(res,cur,open,close+1,n);
cur.pop_back();
}
}
vector<string> generateParenthesis(int n) {
vector<string> res;
backtrack(res,"",0,0,n);
return res;
}
};
3.最大子序和
![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/6c9004e64b11c213d8afb8f639e205bb.png)
class Solution {
public:
int maxSubArray(vector<int>& nums) {
int len = nums.size();
vector<int> dp(len,0);
dp[0] = nums[0];
int res = nums[0];
for(int i=1;i<len;i++){
dp[i] = max(dp[i-1],0)+nums[i];
res = max(res,dp[i]);
}
return res;
}
};
4.跳跃游戏
![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/ce51c4b4e9ef7f8110f1b289cd64ac24.png)
class Solution {
public:
bool canJump(vector<int>& nums) {
int len = nums.size();
int rightmost = 0;
for(int i=0;i<len;i++){
if(i<=rightmost){
rightmost = max(rightmost,i+nums[i]);
}
if(rightmost>=len-1) return true;
}
return false;
}
};
5.不同路径
![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/0e16475983e3204dcedbb715f38d9fea.png)
class Solution {
public:
int uniquePaths(int m, int n) {
vector<vector<int>> dp(m,vector<int>(n,0));
for(int i=0;i<m;i++){
dp[i][0]=1;
}
for(int i=0;i<n;i++){
dp[0][i]=1;
}
for(int i=1;i<m;i++){
for(int j=1;j<n;j++){
dp[i][j] = dp[i-1][j]+dp[i][j-1];
}
}
return dp[m-1][n-1];
}
};
6.最小路径和
![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/7c7f375bac90dd656d4765905528fb0d.png)
class Solution {
public:
int minPathSum(vector<vector<int>>& grid) {
int m=grid.size();
int 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];
}
};
7.买卖股票的最佳时机
![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/cfc143d1bb24225db4732e2737f6a210.png)
class Solution {
public:
int maxProfit(vector<int>& prices) {
int minPrice = INT_MAX;
int profit = 0;
for(int i=0;i<prices.size();i++){
if(prices[i]<minPrice){
minPrice = prices[i];
}else{
profit = max(profit,prices[i]-minPrice);
}
}
return profit;
}
};