快手笔试题
Posted xzxl
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了快手笔试题相关的知识,希望对你有一定的参考价值。
题目:你需要爬上一个N层的楼梯,在爬楼梯的过程中,每阶楼梯需花费非负代价,第 i 阶楼梯花费代价表示cost[i],一旦你付出了代价,你可以在该阶梯基础上往上爬一阶或两阶。在开始时,你可以选择从第 0 阶或第 1 阶开始出发。请计算爬上楼层顶部的最低花费。
输入格式:
1,100,1,100,1,1,100,1,1
输出格式:
6
分析:动态规划。当前最小体力花费=min(距当前位置一阶梯的最小体力花费+走一阶梯的体力花费,距当前位置两阶梯的最小体力花费+走两阶梯的体力花费)。
- dp[i] = min(dp[i-2]+cost[i-2],dp[i-1]+cost[i-1])
求解:
class Solution { public: int minCostClimbingStairs(vector<int>& cost) { if(cost.size()==0){ return 0; } if(cost.size()==1){ return cost[0]; } if(cost.size()==2){ return std::min(cost[0],cost[1]); } int step[1024]; step[0] = 0; step[1] = 0; for(int i=2;i<=cost.size();i++){ step[i] = std::min(step[i-1]+cost[i-1],step[i-2]+cost[i-2]); } return step[cost.size()]; } };
以上是关于快手笔试题的主要内容,如果未能解决你的问题,请参考以下文章
片段(Java) | 机试题+算法思路+考点+代码解析 2023
C语言必会面试题(3耶稣有13个门徒,当中有一个就是出卖耶稣的叛徒,请用排除法找出这位叛徒:13人围坐一圈,从第一个開始报号:1,2,3,1,2,3...。凡是报到“3”就退出圈子,...)(代码片段