leetcode Best_Time_to Buy and Sell_Stock_II

本文介绍了一种计算股票交易最大利润的算法。该算法允许进行多次买卖操作,但每次卖出后才能再次购买。通过遍历股价数组,实现低买高卖来计算总利润。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/**
 * Say you have an array for which the ith element is the price of a given stock on day i.

 * Design an algorithm to find the maximum profit. 
 * You may complete as many transactions as you like *(ie, buy one and sell one share of the stock multiple times). 
 * However, you may not engage in multiple transactions at the same time (ie, you must sell the stock before you buy again).
 *
*/


#include <iostream>
#include <vector>
using namespace std;


class Solution{
public:
     int maxProfit(vector<int>& prices){
        if(prices.size()==0)
            return 0;
        int ans=0;
        for(auto i=prices.begin()+1;i!=prices.end();++i){
            if(*i>*(i-1))       //遍历价格数组低买高卖
                ans+=*(i)-*(i-1);
        }
        return ans;
    }
};


int main()
{

        vector<int> prices = {4, 3, 4, 5, 7, 8, 9, 10, 4, 6, 3};
        Solution s;
        cout << s.maxProfit(prices) << endl;

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值