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

应式网站一般网站建设用什么语言

应式网站,一般网站建设用什么语言,wordpress的意思,濮阳市城乡一体化示范区范围目录 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.yayakq.cn/news/722179/

相关文章:

  • 网站服务器到期了怎么续费深圳市保障性住房轮候申请系统
  • 网站建设创意广告网站设计要多久
  • 海宏集团网站建设酒店网站制作
  • oss如何做网站光做网站推广咋样
  • 安徽网站排名网站怎么做收录
  • 织梦dedecms5.6 网站搬家详细教程产品展示网站设计
  • 洛阳建站推广公司飘雪影视在线观看西瓜
  • 白云区做网站网站seo系统
  • 怎么自己建设公司网站诸城营销型网站建设
  • 浅谈电子商务网站建设与管理在线室内设计
  • 建立网站策划书网站建设 2015年11月
  • 张家港网站优化酒店网站建设流程图
  • 广州做网站推广的公司织梦cms是什么
  • 小米路由器mini做网站广宁城乡建设网站
  • 广东省建站公司安康政务微平台
  • 主流网站开发软件图片优化是什么意思
  • 企业网站建设立项书网站备案密码找回
  • 最简单网站建设网站制作 中企动力公司
  • 红旗网站建设百度搜索网
  • 网站域名怎么填写金属网站模板
  • 网站建设学什么的上海做个网站多少钱
  • 刷网站排名 优帮云大连旅顺景点
  • 内蒙古自治区建设厅网站首页dede后台做两个网站
  • 洛阳制作网站的公司吗湛江wx
  • 网站设计师 要求有没有专门做尾料回收的网站
  • 外包加工网怎么样吕梁seo排名
  • 为网站添加注册功能河南建设厅二建公示网站首页
  • 个人站长适合做什么网站深圳vi设计公司推荐
  • 免费网站建设步骤莆田seo培训
  • 忻州专业网站建设个人主页模板 html