当前位置: 首页 > news >正文

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可以。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 视频检索技术为电子商务直播领域带来了前所未有的革新
  • Objective-C中的MVC架构:构建清晰、可维护的iOS应用
  • 【Hot100】LeetCode—101. 对称二叉树
  • web前端之选项卡的实现、动态添加类名、动态移除类名、动态添加样式、激活、间距、节流、tabBar
  • 【精选】基于python的影片数据爬取与数据分析
  • minio使用与注解事务管理
  • 分享一个基于python的抖音短视频流量数据分析与可视化系统Hive大数据源码(源码、调试、LW、开题、PPT)
  • 并查集详解
  • 内网横向移动常用方法
  • 【Docker】Docker学习01 | 什么是docker?
  • sqlserver索引碎片过大如何处理 sqlserver索引碎片查询
  • 淘宝直播弹幕采集
  • Laravel实现图片上传接口以及图片压缩优化测试
  • 亿发详解:ERP系统选择的艺术——中小企业如何避免实施陷阱?
  • Ingress Nginx Controller
  • ES6指北【2】—— 箭头函数
  • [case10]使用RSQL实现端到端的动态查询
  • axios请求、和返回数据拦截,统一请求报错提示_012
  • Mysql5.6主从复制
  • Python实现BT种子转化为磁力链接【实战】
  • SegmentFault 技术周刊 Vol.27 - Git 学习宝典:程序员走江湖必备
  • select2 取值 遍历 设置默认值
  • WebSocket使用
  • 创建一个Struts2项目maven 方式
  • 多线程事务回滚
  • ------- 计算机网络基础
  • 那些年我们用过的显示性能指标
  • 前端路由实现-history
  • 移动端唤起键盘时取消position:fixed定位
  • 怎样选择前端框架
  • 《TCP IP 详解卷1:协议》阅读笔记 - 第六章
  • FaaS 的简单实践
  • ​Java并发新构件之Exchanger
  • ​RecSys 2022 | 面向人岗匹配的双向选择偏好建模
  • #1015 : KMP算法
  • (3)(3.5) 遥测无线电区域条例
  • (理论篇)httpmoudle和httphandler一览
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • (三)终结任务
  • (十三)Flink SQL
  • (十三)Java springcloud B2B2C o2o多用户商城 springcloud架构 - SSO单点登录之OAuth2.0 根据token获取用户信息(4)...
  • (四)汇编语言——简单程序
  • (算法)求1到1亿间的质数或素数
  • (万字长文)Spring的核心知识尽揽其中
  • (五)activiti-modeler 编辑器初步优化
  • (详细文档!)javaswing图书管理系统+mysql数据库
  • (新)网络工程师考点串讲与真题详解
  • (转)程序员疫苗:代码注入
  • (转)从零实现3D图像引擎:(8)参数化直线与3D平面函数库
  • (转)详解PHP处理密码的几种方式
  • .mysql secret在哪_MySQL如何使用索引
  • .NET 5种线程安全集合
  • .NET CORE使用Redis分布式锁续命(续期)问题
  • .net 前台table如何加一列下拉框_如何用Word编辑参考文献
  • .NET 设计模式—适配器模式(Adapter Pattern)