day38.动态规划+MySql数据库复习

844.比较含退格的字符串

给定 s 和 t 两个字符串,当它们分别被输入到空白的文本编辑器后,如果两者相等,返回 true 。# 代表退格字符。

注意:如果对空文本输入退格字符,文本继续为空

 思路:定义两个栈,将字符加入栈中,遇到#就弹出栈 最后比较栈中剩余元素是否相同

class Solution {//可以直接用栈来比较大小
public:
    bool backspaceCompare(string s, string t) {
        stack<char> st1;
        stack<char> st2;
        for(char c:s){
            if(c=='#'&&!st1.empty()){
                st1.pop();
            }else if(c!='#'){
                st1.push(c);
            }
        }
        for(char m:t){
            if(m=='#'&&!st2.empty()){
                st2.pop();
            }else if(m!='#'){
                st2.push(m);
            }
        }
       while (!st1.empty() &&!st2.empty()) {
            if (st1.top()!= st2.top()) {
                return false;
            }
            st1.pop();
            st2.pop();
        }
        return st1.empty()&&st2.empty();
    }
};

322.零钱兑换

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。

计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。

你可以认为每种硬币的数量是无限的。

 思路:完全背包问题 先遍历物品在遍历背包 

class Solution {
public:
    int coinChange(vector<int>& coins, int amount) {

        vector<int> dp(amount+1,INT_MAX);

        int maxNum=INT_MAX;
        int res=0;
        dp[0]=0;
        for(int i=0;i<coins.size();i++){
            for(int j=coins[i];j<=amount;j++){
              if (dp[j - coins[i]] != INT_MAX) { // 如果dp[j - coins[i]]是初始值则跳过
                    dp[j] = min(dp[j - coins[i]] + 1, dp[j]);
                }
            }
        }
         if (dp[amount] == INT_MAX) return -1;
        return dp[amount];
    }
};

 279.完全平方数

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量 。

完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,1、4、9 和 16 都是完全平方数,而 3 和 11 不是。

 思路:同样是完全背包问题 由于是求完全平方 所以第二个for循环要改成j*j的形式

class Solution {
public:
    int numSquares(int n) {
        //dp[j]代表完全平方数的最少数量

        vector<int> dp(n+1,INT_MAX);
        dp[0]=0;
        for(int i=0;i<=n;i++){//要凑的背包
            for(int j=1;j*j<=i;j++){//用来凑背包的物品
                dp[i]=min(dp[i-j*j]+1,dp[i]);
            }
        }
        return dp[n];
    }
};

139.单词拆分

给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单词拼接出 s 则返回 true。

注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。

 思路:

class Solution {
public:
    bool wordBreak(string s, vector<string>& wordDict) {

    unordered_set<string> wordSet(wordDict.begin(), wordDict.end());
    vector<bool> dp(s.size() + 1, false);
    dp[0]=true;
    for(int i=1;i<=s.size();i++){//背包
        for(int j=0;j<i;j++){//物品
            string word=s.substr(j,i-j);
            if(wordSet.find(word)!=wordSet.end()&&dp[j]){
                dp[i]=true;
            }
        }
    }
    return dp[s.size()];
    }
};

二.MySQL数据库

MySQL数据库是一种关系型数据库,由多张表相互连接的二维表组成的数据库,

SQL语句中的注释:

单行注释:-- 注释内容 或 #注释内容(MySql特有的)--后要加空格

多行注释: /* 注释内容 */

SQL语句的分类: (取自黑马程序员)

 DQL查询语言的语法:

 

 

 聚合函数:

 分组查询:

 1.where和having的区别:

1.执行时机不同:where是分组之前进行过滤,不满足where条件,不参与分组,而having是分组之后对结果进行过滤。

2.判断条件不同:where不能对聚合函数进行过滤,而having可以。

  • 16
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值