
股票问题
发布日期:2021-05-07 06:58:32
浏览次数:35
分类:原创文章
本文共 963 字,大约阅读时间需要 3 分钟。
股票问题
题目链接:
题目大意
这道题就是一个股票,每天有价格。
可以选择买或卖或者不操作。
但一天只能买入或卖出一张。
问能获得的最大利润。
思路
我们考虑贪心。
我们可以想到,买入要低,卖出要高。
那我们可以考虑假设每一个票都买入,然后看哪些票卖出。
然后如果要卖出,就是卖出之前买入最低的那一个。
(能卖出要有股票(假设的),而且买入时价格最小的那一个要低于当前价格)
维护最低的我们可以用堆来实现。
但是有可能你枚举到后面才发现,后面有更优的,但是如果要达到最优,就要把前面已经卖出的股票选择不卖出,然后在这里卖出。
那怎么办呢?
那我们可以通过抵消的方法来搞。
我们让买入的股票价格为 a a a,第一次选择卖出是 b b b 价格时,第二次价格是 c c c。一开始之前选的利润是 a − b a-b a−b,然后我们要让它变成 a − c a-c a−c,那就 + b − c +b-c +b−c。
那其实就是就算前面卖出了,也把当前价格放进去堆里面。
堆里最后会剩下一些假设买入的股票。
这些就是不买入的,就不用管。
代码
#include<queue>#include<cstdio>using namespace std;int n;long long x, ans;priority_queue <long long, vector<long long>, greater<long long> > q;int main() { // freopen("b.in", "r", stdin);// freopen("b.out", "w", stdout); scanf("%d", &n); for (int i = 1; i <= n; i++) { scanf("%lld", &x); if (!q.empty() && q.top() <= x) { ans += x - q.top();//在这里卖出一张股票 q.pop(); q.push(x);//假设又买进去(就是变成不买) } q.push(x); } printf("%lld", ans); fclose(stdin); fclose(stdout); return 0;}
发表评论
最新留言
很好
[***.229.124.182]2025年04月02日 20时14分51秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
B1021 个位数统计 (15 分)
2019-03-04
java中的字符串
2019-03-04
Idiot 的间谍网络
2019-03-04
MySql索引及使用、实现的数据结构
2019-03-04
初探SSRF漏洞
2019-03-04
pythonBug入门——从零开始学python
2019-03-04
js中[]、{}、()的区别
2019-03-04
js-禁止右键菜单代码、禁止复制粘贴代码
2019-03-04
SpringBoot中使用Mybatis访问MySQL数据库(使用xml方式)
2019-03-04
$set的使用(视图不能实时更新)
2019-03-04
【SSL】1072砝码称重
2019-03-04
js数据结构--队列--常见操作
2019-03-04
多项式插值法的Python程序
2019-03-04
vue.js常用指令及用法
2019-03-04
vuex的核心概念和运行机制
2019-03-04
SSLOJ1692 USACO 3.2 Magic Squares 魔板&P2730
2019-03-04
暴打算法:王者级数据结构与LeetCode笔记,一路绿灯杀进字节Java岗
2019-03-04
限时开源!公布半小时下载量达10W:阿里大牛出品「MyCat笔记」
2019-03-04
阿里Java全线成长宝典,从P5到P8一应俱全
2019-03-04
计算机系统原理——cachelab 实验1(第一周)
2019-03-04