【20221215】【每日一题】爬楼梯进阶(ACM模式)
创始人
2024-04-23 22:35:13
0

在爬楼梯的基础上,改为一次可以爬1阶、2阶、...一直到m阶,问一共有多少种办法爬到楼顶?


思路:这是一个完全背包问题,因为爬完一阶后,还可以再爬一阶,可以重复取;

动规五部曲

1、dp数组下标及其含义:背包容量为j的背包一共有dp[j]种办法装满;

2、递推关系式:背包装满的问题、dp[j]+=dp[j-nums[i]];

3、初始化:dp[0]=1,其余为0;

4、遍历顺序:归根到底还是排序问题,不同的顺序可以视为不同的方法,先背包后物品,背包为正序。

5、举例验证dp数组。


1、getline使用方法:getline(<字符数组chs>,<读取字符的个数n>,<终止符>)

2、stoi:string to int

3、find_if用法:按功能查找元素  

  • find_if( iterator beg, iterator end, _pred)
  • 按值查找元素,找到的话返回指定位置的迭代器,找不到则返回结束迭代器位置
  • beg :开始迭代器
  • end :结束迭代器
  • _pred :函数或者谓词 (返回bool类型的仿函数)

例子:

class GreaterFive
{
public:bool operator()(int val){return val > 5;}
};void test1()
{vector v;for (int i = 0; i < 10; i++){v.push_back(i);}vector::iterator pos = find_if(v.begin(), v.end(), GreaterFive());if (pos == v.end()){cout << "未找到!" << endl;}else{cout << "找到>5的数字:" << *pos << endl;}
}

 

#include 
#include 
#include 
#include 
using namespace std;
class Solution {
public:int combinationSum4(vector& nums, int target) {//初始化vector dp(target + 1, 0);dp[0] = 1;//遍历顺序 由于要求为排列结果,所以先背包、后物品for (int j = 0; j <= target; j++){for (int i = 0; i < nums.size(); i++){if (j >= nums[i] && dp[j] < INT_MAX - dp[j - nums[i]])  dp[j] += dp[j - nums[i]];}}return dp[target];}
};void trimLeftTrailingSpaces(string& input) {input.erase(input.begin(), find_if(input.begin(), input.end(), [](int ch) {return !isspace(ch);}));
}void trimRightTrailingSpaces(string& input) {input.erase(find_if(input.rbegin(), input.rend(), [](int ch) {return !isspace(ch);}).base(), input.end());
}vector stringToIntegerVector(string input) {vector output;trimLeftTrailingSpaces(input);trimRightTrailingSpaces(input);input = input.substr(1, input.length() - 2);stringstream ss(input);ss.str(input);string item;char delim = ',';while (getline(ss, item, delim)) {output.push_back(stoi(item));}return output;
}int stringToInteger(string input) {return stoi(input);
}int main() {string line;while (getline(cin, line)) {vector nums = stringToIntegerVector(line);getline(cin, line);int target = stringToInteger(line);int ret = Solution().combinationSum4(nums, target);string out = to_string(ret);cout << out << endl;}return 0;
}

相关内容

热门资讯

资本界金控(00204.HK)... 格隆汇7月2日丨资本界金控(00204.HK)公告,公司近期与江苏福万代科技信息有限公司("福万代"...
新希望:独立董事彭龙接受纪律审... 转自:财联社【新希望:独立董事彭龙接受纪律审查和监察调查】财联社7月2日电,新希望公告,公司独立董事...
3岁萌娃迷路街头,妈妈急疯!两... 来源:杭州公安 “你好 我在天万街与羊头坝路交叉口的桥上 这边有个小孩子找不到家人一直在哭” 6月2...
中考成绩单|低波策略业绩盘点 (转自:国泰基金微幸福)
华菱钢铁:投资者建议连续三年回... 投资者提问:回购注销是财务手段里提升pb最稳定最可靠最有效的方式,在pb回升到1之前,每年分红可以少...
今年前5个月销量排名前十位轿车... 转自:北京商报北京商报讯(记者 刘晓梦)7月2日,据中国汽车工业协会统计分析,今年前5个月,销量排名...
法国已有2人死于热浪 转自:新华社新华社巴黎7月2日电(记者罗毓)法国商业调频电视台2日上午报道,最近该国遭遇强热浪天气,...
赛意信息(300687.SZ)... 格隆汇7月2日丨赛意信息(300687.SZ)公布,截至2025年6月30日,公司通过股份回购专用证...
比亚迪汽车:海洋网累计销售超5... 7月2日,比亚迪汽车官方微博显示,比亚迪海洋网6月热销196766辆,同比增长24.6%。2025年...
能特科技:拟以3亿元-5亿元回... 格隆汇7月2日|能特科技公告,公司拟使用自有资金及自筹资金,本次回购股份将全部用于注销并相应减少注册...