代码拉取完成,页面将自动刷新
同步操作将从 star/offer100 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
<?php
/**
* 包含min函数的栈
* 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。
* 思路:最小辅助栈,
* push stack minstcak
* 5 5 5
* 6 6 5
* 7 7 5
* 4 4 4
* 1 1 1
* 8 8 1
* minstcak 中在stack每次push中都要压入,且只压入当前的最小值
* stack 每次pop是,同时minstcak也要minstack
*/
class MinStack
{
private static $stack = [];
private static $minStack = [];
public static function mypush($node)
{
array_push(static::$stack, $node);
if (count(static::$minStack) > 1) {
$min = static::$minStack[count(static::$minStack) - 1];
if ($node < $min) {
array_push(static::$minStack, $node);
} else {
array_push(static::$minStack, $min);
}
} else {
array_push(static::$minStack, $node);
}
}
public static function mypop()
{
array_pop(static::$minStack);
return array_pop(static::$stack);
}
public static function mytop()
{
if (count(static::$stack) > 0) {
return static::$stack[count(static::$stack) - 1];
}
return null;
}
public static function mymin()
{
if (count(static::$minStack) > 0) {
return static::$minStack[count(static::$minStack) - 1];
}
return null;
}
}
MinStack::mypush(5);
MinStack::mypush(2);
MinStack::mypush(3);
MinStack::mypush(1);
MinStack::mypush(10);
//echo MinStack::mypop();
echo MinStack::mytop();
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。