當前位置: 首頁>>代碼示例>>Python>>正文


Python Stack.peek方法代碼示例

本文整理匯總了Python中Stack.peek方法的典型用法代碼示例。如果您正苦於以下問題:Python Stack.peek方法的具體用法?Python Stack.peek怎麽用?Python Stack.peek使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Stack的用法示例。


在下文中一共展示了Stack.peek方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: NewStack

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
class NewStack():
	def __init__(self):
		self.Stack = Stack()
		self.minStack = Stack()
		self.tempMin = None

	def isEmpty(self):
		return self.Stack.isEmpty()

	def push(self, item):
		if self.tempMin == None or item < self.tempMin:
			self.tempMin = item
		self.Stack.push(item)
		self.minStack.push(self.tempMin)

	def pop(self):
		self.minStack.pop()
		return self.Stack.pop()

	def min(self):
		return self.minStack.peek()

	def peek(self):
		return self.Stack.peek()

	def size(self):
		return self.Stack.size()
開發者ID:Jason-Yuan,項目名稱:Interview-Code,代碼行數:29,代碼來源:Chapter3-2.py

示例2: __init__

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
class MaxStack:
     def __init__(self):
         self.base = Stack()
         self.max = Stack()
     def push(self, item):
        if item >= self.max.peek():
            self.max.push(item)
        self.base.push(item)
     def pop(self):
         val = self.base.pop()
         if (val == self.max.peek()):
             self.max.pop()
         return val
     def getmax(self):
         return self.max.peek()
開發者ID:gautamgitspace,項目名稱:CTCIv5.0,代碼行數:17,代碼來源:largest-stack.py

示例3: infix_to_postfix

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
def infix_to_postfix(infix_expr):
	
	token_list = infix_expr.split()
	op_stack = Stack()
	postfix_list = []
	prec = {"*":3, "/":3, "+":2, "-":2, "(":1}
	
	for token in token_list:
		if token in "0123456789" or token in "ABCDEFGHIJKLMNOPQRSTUVWXYZ":
			postfix_list.append(token)
		
		elif token == "(":
			op_stack.push(token)
		elif token == ")":
			top_token = op_stack.pop()
			while top_token != "(":
				postfix_list.append(top_token)
				top_token = op_stack.pop()
		else:
			while (not op_stack.is_empty()) and prec[op_stack.peek()] >= prec[token]:
				postfix_list.append(op_stack.pop())
			op_stack.push(token)
	
	while (not op_stack.is_empty()):
		postfix_list.append(op_stack.pop())
	
	return " ".join(postfix_list)

#print infix_to_postfix("A + B + C + D")
#print infix_to_postfix("( A + B ) * ( C + D ) ")
#print infix_to_postfix("A + B * C + D")
開發者ID:Xiaoke1982,項目名稱:AlgorithmAndDataStructureInPython,代碼行數:33,代碼來源:infix_to_postfix.py

示例4: SortStack

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
def SortStack(mystack):
	HelpStack = Stack()
	while not mystack.isEmpty():
		MaxValue = mystack.pop()
		while not HelpStack.isEmpty() and HelpStack.peek() > MaxValue:
			mystack.push(HelpStack.pop())
		HelpStack.push(MaxValue)

	return HelpStack
開發者ID:Jason-Yuan,項目名稱:Interview-Code,代碼行數:11,代碼來源:Chapter3-6.py

示例5: DFS_iterative

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
def DFS_iterative(Graph, node, nodes_list):
    global time
    stack = Stack()
    stack.push(node)
    while not stack.isEmpty():
        nodes_list[node].explore()
        nodes_list[node].set_leader(source_node)
        node = stack.peek()
        if len(Graph[node]) != 0:
            linked_node = Graph[node].pop()
            if nodes_list[linked_node].get_not_explored():
                stack.push(linked_node)
        else:
            time += 1
            nodes_list[stack.pop()].set_time(time)
開發者ID:LorenzoBi,項目名稱:algorithm_design,代碼行數:17,代碼來源:Kosaraju_algorithm.py

示例6: MyQueue

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
class MyQueue(object):
    def __init__(self):
        self.firstStack = Stack()
        self.secondStack = Stack()
        
    def enqueue(self, item):
        self.firstStack.push(item)
        
    def dequeue(self):
        if self.secondStack.size() == 0:
            while self.firstStack.size() > 0:
                self.secondStack.push(self.firstStack.pop())
        return self.secondStack.pop()

    def peek(self):
        if self.secondStack.size() == 0:
            while self.firstStack.size() > 0:
                self.secondStack.push(self.firstStack.pop())
        return self.secondStack.peek()

    def isEmpty(self):
        return self.firstStack.size() == 0 and self.secondStack.size() == 0
開發者ID:Jason-Yuan,項目名稱:Interview-Code,代碼行數:24,代碼來源:Chapter3-5.py

示例7: infix2postfix

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
def infix2postfix(expr):
	stck=Stack()
	pof_expr=[]
	for each in expr:
		x=typeof(each)
		if x is "lpar":
			stck.push(each)
		elif x is "rpar":
			next_item=stck.pop()
			while typeof(next_item) is not "lpar":
				pof_expr.append(next_item)
				next_item=stck.pop()
		elif x is "oprand":
			pof_expr.append(each)
		elif x is "empty":
			continue
		elif x is "oprator":
			while stck.size() is not 0 and precedence(each)<=precedence(stck.peek()):
				pof_expr.append(stck.pop())
			stck.push(each)

	while stck.size()>0:
		pof_expr.append(stck.pop())
	print ''.join(pof_expr)
開發者ID:sanchiaman,項目名稱:python_github,代碼行數:26,代碼來源:infix2postfix.py

示例8: infixToPostfix

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
def infixToPostfix(infixexpr):
    # First set up a dictionary mapping symbols to
    # precedence.
    prec = {}
    prec["*"]= 3
    prec["/"]= 3
    prec["+"]= 2
    prec["-"]= 2
    prec["("]= 1
    # Split the input into tokens.
    tokenList = infixexpr.split()
    # We’ll need a stack and an output stream.
    opStack = Stack()
    outputList = []
    for token in tokenList:
        # Is token a number?
        if token.isdigit():
            outputList.append(token)
        elif token == "(":
            opStack.push(token)
        elif token == ")":
            topToken = opStack.pop()
            while topToken != "(":
                outputList.append(topToken)
                topToken = opStack.pop()
        else:
            while (not opStack.isEmpty()) and \
                  (prec[opStack.peek()] >= prec[token]):
                outputList.append(opStack.pop())

            opStack.push(token)
                                
    while not opStack.isEmpty():
        outputList.append(opStack.pop())
    #print(" ".join(outputList))
    return " ".join(outputList)
開發者ID:keachico,項目名稱:CS303E_and_CS313E,代碼行數:38,代碼來源:Calculator.py

示例9: infixToPostfix

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
def infixToPostfix(infixexpr):
    """Input may contain positive integer constants and the following operators:
    + (plus), - (minus), * (times), and parentheses. Use spaces to
    separate tokens in your input. That is, you should input "( 12 + 7 ) * 3"
    rather than "(12+7)*3"."""

    # First set up a dictionary mapping symbols to
    # precedence.
    prec = {}
    prec["*"] = 3
    prec["/"] = 3
    prec["+"] = 2
    prec["-"] = 2
    prec["("] = 1
    prec[""]  = 0
    
    # Split the input into tokens.
    tokenList = infixexpr.split()
    
    # We’ll need a stack and an output stream.
    opStack = Stack()
    outputList = []

    for token in tokenList:
        # Is token a number?
        if token.isdigit():
            outputList.append(token)
        elif token.isalpha():
            print("Variables are not allowed")
            return None
        elif token == "(":
            opStack.push(token)
        elif token == ")":
            if opStack.isEmpty():
                print("Ill-formed expression")
                return None
            else:
                topToken = opStack.pop()
                while topToken != "(":
                    outputList.append(topToken)
                    if opStack.isEmpty():
                        print("Ill-formed expression")
                        return None
                    else:
                        topToken = opStack.pop()
        elif token in ('+', '-', '/', '*', '('):
            while (not opStack.isEmpty()) and \
            (prec[opStack.peek()] >= prec[token]):
                if opStack.isEmpty():
                    print("Ill-formed expression")
                    return None
                else:
                    outputList.append(opStack.pop())
                            
            opStack.push(token)
        else:
            print("Ill-formed expression")
            return None
    while not opStack.isEmpty():
        outputList.append(opStack.pop())
    return " ".join(outputList)
開發者ID:Taylor4484,項目名稱:CS-313E---Elements-of-Software-Design,代碼行數:63,代碼來源:Calculator.py

示例10: Stack

# 需要導入模塊: import Stack [as 別名]
# 或者: from Stack import peek [as 別名]
import Stack as Stack

s = Stack()

print(s.isEmpty())
s.push(4)
s.push("dog")
print(s.peek())
s.push(True)
print(s.size())
print(s.isEmpty())
s.push(8.4)
print(s.pop())
print(s.pop())
print(s.size())
開發者ID:dksingh04,項目名稱:DataStructure-And-Algorithm,代碼行數:17,代碼來源:testStack.py


注:本文中的Stack.peek方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。