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

沧州做网站哪家公司好网络服务公司

沧州做网站哪家公司好,网络服务公司,外贸网站建设推广公司价格,邯郸市网站建设目录 LeetCode 322. 零钱兑换 LeetCode 279. 完全平方数 LeetCode 139. 单词拆分 总结 LeetCode 322. 零钱兑换 题目链接:LeetCode 322. 零钱兑换 思想:首先定义dp数组的含义,dp[j]即总金额为j的情况下所需的最少的硬币个数。接下来确定…

目录

LeetCode 322. 零钱兑换

LeetCode 279. 完全平方数

LeetCode 139. 单词拆分

总结


LeetCode 322. 零钱兑换

题目链接:LeetCode 322. 零钱兑换

思想:首先定义dp数组的含义,dp[j]即总金额为j的情况下所需的最少的硬币个数。接下来确定dp数组的递推公式,即在总金额为j的情况下,所需要的硬币个数可以是当前值即dp[j],也可以是减掉当前硬币面值的前一个dp[j-coins[i]] + 1的值。因为要求最小,所以取他俩的最小值。而关于dp数组的初始化,因为要求的值是最小值,所以所有的数都取INT_MAX;其次,dp数组的所有数都是根据dp[0]的值求出的,所以dp[0]要初始化为0,这有什么意义呢,其实也没啥意义。最后要确定循环的顺序,因为这里只需要找到最少的硬币个数,所以组合和排序的顺序都可以,其次这里是一个完全背包问题,所以容量要从小到大遍历。

代码如下:

    int coinChange(vector<int>& coins, int amount) {vector<int> dp(amount + 1, INT_MAX);dp[0] = 0;for (int i = 1; i <= amount; i++) {  // 遍历背包for (int j = 0; j < coins.size(); j++) { // 遍历物品if (i - coins[j] >= 0 && dp[i - coins[j]] != INT_MAX ) {dp[i] = min(dp[i - coins[j]] + 1, dp[i]);}}}if (dp[amount] == INT_MAX) return -1;return dp[amount];}

时间复杂度:O(n^2),空间复杂度:O(n)。

LeetCode 279. 完全平方数

题目链接:LeetCode 279. 完全平方数

思想:首先确定dp数组含义,dp[j]即总和为j的完全平方的最少数量。dp的递推公式、初始化和循环遍历顺序跟上题一样。本题要注意一点就是在循环物品的种类的时候,要对n取平方根处理,这样才好计算完全平方数。

代码如下:

    int numSquares(int n) {vector<int> dp(n + 1, INT_MAX);dp[0] = 0;int size = sqrt(n);for (int i = 1; i <= size; i++) {int weight = i * i;for (int j = weight; j <= n; j++) {dp[j] = min(dp[j - weight] + 1, dp[j]);}}return dp[n];}

时间复杂度:O(n^2),空间复杂度:O(n)。

LeetCode 139. 单词拆分

题目链接:LeetCode 139. 单词拆分

思想:本题确实没怎么搞懂,没把它化解成完全背包问题。遂看题解。首先dp数组的含义就是,长度为j的字符串是否可以用字典里面的字符串来拼接。递推公式,如果确定dp[j]是true,且[j,i]在这个区间的子串出现在字典里,那么dp[i]一定是true。所以递推公式是 if([j, i] 这个区间的子串出现在字典里 && dp[j]是true)那么 dp[i] = true。从递推公式中可以看出,dp[i] 的状态依靠 dp[j]是否为true,那么dp[0]就是递推的根基,dp[0]一定要为true,否则递推下去后面都都是false了。本题是求拼接成一个字符串,每个字典里的字符串的位置不固定,所以本题应该是排列数问题,所以先循环背包,再循环遍历物品。

代码如下:

    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] == true) {dp[i] = true;}}}return dp[s.size()];}

时间复杂度:O(n^2),空间复杂度:O(n)。

总结

今天做的昏头昏脑,还得是要多练习才行。

http://www.khdw.cn/news/26590.html

相关文章:

  • 网站描述怎样写一个自己的网站
  • 咸阳建设网站如何seo推广
  • 怎样利用网站做推广市场调研报告1000字
  • b2b电子商务网站主要是以零售为主潍坊网站排名提升
  • 代做效果图的网站关键词搜索指数查询工具
  • 网站psd下载天津seo推广优化
  • 网站开发语言分为几种怎么样创建网站
  • 做本地的门户网站竞价推广课程
  • 万维网申请网站域名seo服务内容
  • 网页美工设计师培训郑州seo公司
  • 怎样做网站结构优化专业做网站的公司
  • 学院网站建设目的站长统计app网站
  • wordpress test新区快速seo排名
  • 网站建设案例私人做网站的流程
  • 公司建设门户网站的意义年度关键词
  • 做网站云服务器选择多大带宽百度今日排行榜
  • 软文网站备案如何查询seo关键词首页排名
  • 哪家建公司网站网盘搜索引擎
  • 外贸电商网站制作如何交换优质友情链接
  • 济南网络优化推广seo快速排名软件网址
  • 做五金标准件网站搜索引擎优化答案
  • 网站建设费应计入什么科目微信营销的方法和技巧
  • 琴童少儿音乐创作网站建设全网搜索关键词查询
  • 网站开发经典案例抖音引流推广怎么做
  • 企业网站源码简约宁波seo外包优化公司
  • 做网站功能模块网络推广常见的方法
  • 雄安做网站价格西部数码域名注册官网
  • wordpress 建站容易吗长沙网站推广智投未来
  • 建设银行网站怎么取消短信服务seo网站优化方案
  • 泉州做网站建设黑帽seo排名