- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
有一个经典的面试问题,利润最大化,一次交易买股票,允许n次交易和k次交易。
有人问我类似的问题,但有一个扭曲约束:您可以多次购买股票(任何一天不超过一个单位),但您不能在卖出股票后购买。
这有一个你只卖一次的引理。
例如:70 40 90 110 80 100
选项 1:B B B 卖出 _ _ = 130
选项 2:B B B X B 卖出 = 120
老问题
https://www.geeksforgeeks.org/stock-buy-sell/
https://www.geeksforgeeks.org/maximum-profit-by-buying-and-selling-a-share-at-most-twice/
https://www.geeksforgeeks.org/maximum-profit-by-buying-and-selling-a-share-at-most-k-times/
Stackoverflow 讨论
maximizing profit for given stock data via DP
Maximizing profit for given stock quotes
Maximum profit by buying and selling a share exactly k times
最佳答案
这可以在 O(n lg n)
中解决与 O(n)
使用 BST 的空间。
class BSTNode{
BSTNode(val){
this.val = val
this.sum = sum
this.left = this.right = null
this.count = 1
}
insert(val){
if(val < this.val)
insert val into the left subtree
else if(val > this.val)
insert val into the right subtree
this.sum += val
this.count++
}
count_sum_nodes_upper_bound(val){
if(val < this.val)
return this.left.sum_nodes_lower_bound(val)
else if(val == this.val)
return this.left.sum, this.left.count
else{
right_sum, right_count = this.right.sum_nodes_lower_bound(val)
return (this.sum - this.right.sum + right_sum),
(this.count - this.right.count + right_count)
}
}
}
以上只是适当的 BST 应该是什么样子的粗略概述。在实践中,您可能希望改用平衡树并检查 count_sum_nodes_lower_bound
中是否存在子树。 .上面代码解释:
每个BSTNode
除了 BST 的标准属性外,还拥有属性 sum
和 count
, 其中count
是子树中元素的数量,sum
是其中所有元素的总和。
Insert 的工作方式与它在普通 BST 中的工作方式相同,除了在每个节点中对应的 sum
。和 count
需要更新。如果多次插入相同的值,sum
和 count
将更新以反射(reflect)口是心非。
然而,核心部分是方法 count_sum_nodes_upper_bound
,计算给定上限的元素计数及其总和。对于给定的上限 b
值 v
的节点上可能发生三种情况:
b < v
: 所有相关的元素都包含在左子树中b == v
: 左子树为查询结果b > v
:左子树和当前节点中的所有值都是子集的一部分。另外右子树的一些节点也是结果的一部分,我们需要通过递归找到。有了这个 BST,我们现在可以轻松找到上述问题的解决方案:
maximize_profit(A){
node = BSTNode(A[0])
max = 0
max_idx = -1
for(i in 1..(A.length - 1)){
sum, count = node.count_sum_nodes_upper_bound(A[i])
gain = A[i] * count - sum
if(max < gain){
max = gain
max_idx = i
}
node.insert(A[i])
}
return max_idx
}
上述代码根据存储在 BST 中的值找到最佳销售日期的索引。在迭代开始时 i
, node
将包含 A[0..i - 1]
中的所有值.唯一值得购买的股票是那些值(value)低于 A[i]
的股票.我们可以在O(lg n)
中查询这些股票的数量和总和。使用 count_sum_nodes_upper_bound
.如果总和为 s
,则这些股票的总 yield 和他们的数量 c
然后是所有股票的卖出价 (A[i] * c
) 减去每只股票的买入价 (s
)。
购买股票之后可以在 O(n)
中轻松完成通过过滤A
(或根据您的需要扩展 BST 的功能)。
关于algorithm - 面试题: Buy and sell stocks to maximize profit with constraint of not buying once you sell,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54151834/
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
我正在尝试弄清楚如何在单击“立即购买”按钮时使用单选按钮从表单中提取数据。我知道在 react 中你可以获取值并设置状态,但我正在尝试使用一个 ajax 调用,我不是 100% 了解如何设置它。我尝试
我注意到我的一位 friend 在使用它。 » Buy for $1,691 如果我使用它,我感觉没有任何变化。 » Buy for $1,691 那么谁能解释一下两者的区别是什么? 只是想知道为什么
有一个经典的面试问题,利润最大化,一次交易买股票,允许n次交易和k次交易。 有人问我类似的问题,但有一个扭曲约束:您可以多次购买股票(任何一天不超过一个单位),但您不能在卖出股票后购买。 这有一个你只
我在窗体上有两个按钮,其中一个按钮包含货币代码(EUR,USD,GBP,CHF等),另一个按钮-交易方向(买入或卖出)。还有一些实用程序通过文本来识别按钮。 为了识别带有货币的按钮,我使用了正则表达式
我发现这段代码可以在 iOS 9 上使用 swift 2 执行应用内购买。我的 IAP(应用内购买)将位于表格中。它将显示为一条提醒消息,您可以在其中点击购买 或取消。如果您点击购买,则会显示来自 A
对于产品系列页面 ( https://bloomthis.co/collections/on-demand-blooms ),当每个产品悬停在上面时,会显示替代图像。备用图片是产品页面中添加的最后一张
这个问题在这里已经有了答案: 关闭 10 年前。
我正在开发一个允许人们在IOS应用程序中提出某种问题的应用程序,在后端,有人(人类)可以回答这些问题。显然,答案有些延迟(10分钟-1小时)。 我可以为此使用In App Purchase模式(消耗品
我希望使用 ES6、react、react-redux 和您的 js-buy-sdk api 构建一个电子商务 Web 应用程序。我的问题是,从shopify获取所有产品并将它们放入商店后,我似乎没有
我正在使用 Shopify 的 BUY SDK 创建自定义店面。 import Client from 'shopify-buy' const client = Client.buildClient(
我正在尝试在应用程序购买中使用 Android。我使用的是官方文档和 util(Base64 等)。我正在使用托管 项目。我在哪里以及如何处理已经购买的元素? (我将 bool 值设置为 true 并
我正在使用 shopify buy SDK 创建自定义店面: 我在尝试添加订单项时遇到错误 下面的示例代码都可以正常工作,但遇到“addLineItems”方法时除外:我已经检查了参数,它们似乎没问题
我目前有应用内购买“恢复”按钮, 它确实工作,但本质上它要求用户在整个过程中“购买”升级(就像普通的应用程序内一样)我担心这会 a) 被苹果拒绝b) 吓唬用户,让他们认为他们再次付费 有什么办法可以改
我的教授指示我们制作一个类似星巴克的菜单,用户可以在其中继续输入订单直到完成。我在循环中显示了菜单,但无法将输入的订单相加并显示总数。 #include using namespace std; i
过去 15 天试图解决 paypal 问题,在 PayPal 升级后,我的客户在付款时遇到问题,前几天它有时工作正常但现在只显示错误。 在我选择要购买的商品并单击“立即购买”按钮后,paypal 显示
我在网站上工作,我需要与 Payza 集成。从我读到的“立即购买”按钮看起来像这样: 这是不安全的。 Payza 是否提供任何 API 来保护我的按钮(例如 P
我正在使用 Paypal 的“立即购买”按钮,我很困惑为什么它不起作用(我以前做过)。 我在 Paypal 上创建了一个“立即购买”按钮,并取消选中“在 Paypal 上保存此按钮”- 因此它没有托管
我有一个集成了 Facebook SDK 的 iOS 应用程序,并且我一直在运行 Facebook 的按安装付费事件。 最近尝试为另一个具有相同 SDK 的应用程序设置此功能,但我在设置 Facebo
我目前正在使用 Shopify Buy Button . 在大多数情况下,我只是复制并粘贴了嵌入代码,并没有做太多更改。 我有一些产品需要购买 5 件或更多的所述商品。 典型的添加到购物袋按钮只添加一
我是一名优秀的程序员,十分优秀!