当前位置: 首页>>代码示例>>C#>>正文


C# Stack.Pop方法代码示例

本文整理汇总了C#中Stack.Pop方法的典型用法代码示例。如果您正苦于以下问题:C# Stack.Pop方法的具体用法?C# Stack.Pop怎么用?C# Stack.Pop使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Stack的用法示例。


在下文中一共展示了Stack.Pop方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Stack

        private static int Stack(string rpn)
        {
            string operators = "+-*/";
            Func<int, int, int>[] functions = new Func<int, int, int>[]
            {
                (x, y) => x + y,
                (x, y) => x - y,
                (x, y) => x * y,
                (x, y) => x / y,
            };

            string[] tokens = rpn.Split(',');
            Stack<int> values = new Stack<int>();

            foreach(string token in tokens)
            {
                int index = operators.IndexOf(token);
                if (index == -1)
                {
                    values.Push(int.Parse(token));
                    continue;
                }

                int y = values.Pop();
                int x = values.Pop();

                values.Push(functions[index](x, y));
            }

            return values.Pop();
        }
开发者ID:mmoroney,项目名称:Algorithms,代码行数:31,代码来源:EvaluateRPN.cs

示例2: LargestRectangleArea

        public int LargestRectangleArea(int[] height)
        {
            var stack = new Stack<int>();
            int i = 0, maxArea = 0, topIndex = 0;

            while (i < height.Length)
            {
                if (stack.Count == 0 || height[i] > height[stack.Peek()])
                {
                    stack.Push(i++);
                    continue;
                }

                topIndex = stack.Pop();
                maxArea = Math.Max(
                    maxArea,
                    height[topIndex] * (stack.Count == 0 ? i : i - stack.Peek() - 1));
            }

            while (stack.Count != 0)
            {
                topIndex = stack.Pop();
                maxArea = Math.Max(
                    maxArea,
                    height[topIndex] * (stack.Count == 0 ? i : i - stack.Peek() - 1));
            }

            return maxArea;
        }
开发者ID:BigEgg,项目名称:LeetCode,代码行数:29,代码来源:084-LargestRectangleInHistogram.cs

示例3: Print

        private static void Print(Stack<int> stack)
        {
            while (stack.Count > 0)
            {
                if (stack.Count == 1)
                {
                    Console.Write(stack.Pop());
                }
                else
                {
                    Console.Write(stack.Pop() + ",");
                }

            }
            Console.WriteLine();
            for (int i = 0; i < labyrinth.GetLength(0); i++)
            {
                for (int j = 0; j < labyrinth.GetLength(1); j++)
                {
                    Console.Write("{0, 2} ", labyrinth[i, j]);
                }
                Console.WriteLine();
            }
            Console.WriteLine();
        }
开发者ID:kikooo52,项目名称:TelerikAkademy,代码行数:25,代码来源:Program.cs

示例4: StackThrowsException_WhenPopOnEmpty

 public void StackThrowsException_WhenPopOnEmpty()
 {
     var st = new Stack<int>();
     st.Push(1);
     var item = st.Pop();
     st.Pop();
 }
开发者ID:venkatavitakula,项目名称:dspractise,代码行数:7,代码来源:StackTest.cs

示例5: Format

        public string Format(string format, object arg, IFormatProvider provider)
        {
            if (arg == null || format != "Hx")
                return String.Format(parent,"{0:" + format + "}", arg);
            StringBuilder hexString = new StringBuilder();
            Stack<int> stack = new Stack<int>();
            int popped,delta, dec, providerBase = 16;
            try
            {
                dec = (int)arg;
            }
            catch (InvalidCastException ex)
            {

                throw new InvalidCastException("DecimalToHexProvider must recieve numerical type",ex);
            }

            while (dec != 0)
            {
                stack.Push(dec);
                dec /= providerBase;
            }
            delta = popped = stack.Pop();
            hexString.Append(hexCharacters[delta]);
            while (stack.Count > 0)
            {

                delta = stack.Peek() - popped * providerBase;
                hexString.Append(hexCharacters[delta]);
                popped = stack.Pop();

            }
            return hexString.ToString();
        }
开发者ID:VladislavMedved,项目名称:Day1,代码行数:34,代码来源:DecimalToHexProvider.cs

示例6: Main

 static void Main()
 {
     var test = new Stack<int>();
     test.Push(1);
     Console.WriteLine(string.Join(" ", test.ToArray()));
     test.Push(2);
     Console.WriteLine(string.Join(" ", test.ToArray()));
     test.Push(3);
     Console.WriteLine(string.Join(" ", test.ToArray()));
     test.Push(4);
     Console.WriteLine(string.Join(" ", test.ToArray()));
     test.Push(5);
     Console.WriteLine(string.Join(" ", test.ToArray()));
     test.Push(6);
     Console.WriteLine(string.Join(" ", test.ToArray()));
     test.Push(7);
     Console.WriteLine(string.Join(" ", test.ToArray()));
     Console.WriteLine("The stack count: {0}", test.Count);
     test.Pop();
     test.Pop();
     Console.WriteLine(string.Join(" ", test.ToArray()));
     Console.WriteLine("The stack count: {0}", test.Count);
     Console.WriteLine(test.Peek());
     Console.WriteLine(string.Join(" ", test.ToArray()));
     Console.WriteLine("The stack count: {0}", test.Count);
     test.Clear();
     Console.WriteLine(string.Join(" ", test.ToArray()));
     Console.WriteLine("The stack count: {0}", test.Count);
     //test.Pop();                           //if uncommented this line should throw exception
 }
开发者ID:kalinalazarova1,项目名称:TelerikAcademy,代码行数:30,代码来源:StackTest.cs

示例7: ReadPassword

        /// <summary>
        /// Like System.Console.ReadLine(), only with a mask.
        /// </summary>
        /// <param name="mask">a <c>char</c> representing your choice of console mask</param>
        /// <returns>the string the user typed in </returns>
        public static string ReadPassword(char mask)
        {
            const int ENTER = 13, BACKSP = 8, CTRLBACKSP = 127;
            int[] filtered = { 0, 27, 9, 10 /*, 32 space, if you care */ }; // const

            var pass = new Stack<char>();
            char chr;

            while ((chr = Console.ReadKey(true).KeyChar) != ENTER) {
                if (chr == BACKSP) {
                    if (pass.Count > 0) {
                        Console.Write("\b \b");
                        pass.Pop();
                    }
                }
                else if (chr == CTRLBACKSP) {
                    while (pass.Count > 0) {
                        Console.Write("\b \b");
                        pass.Pop();
                    }
                }
                else if (filtered.Count(x => chr == x) > 0) { }
                else {
                    pass.Push(chr);
                    Console.Write(mask);
                }
            }

            Console.WriteLine();

            return new string(pass.Reverse().ToArray());
        }
开发者ID:NansenViktor,项目名称:wia,代码行数:37,代码来源:ConsoleEx.cs

示例8: Print

        private static void Print(Node<int> nodeOne)
        {
            var result = new Stack<int>();
            var currentNode = nodeOne;
            while (currentNode.Previous != null)
            {
                result.Push(currentNode.Value);
                currentNode = currentNode.Previous;
            }
            result.Push(currentNode.Value);

            var sb = new StringBuilder();
            while (result.Count > 0)
            {
                if (sb.Length == 0)
                {
                    sb.Append(result.Pop());
                }
                else
                {
                    sb.Append(" - >" + result.Pop());
                }
            }
            System.Console.WriteLine(sb.ToString());
        }
开发者ID:nzhul,项目名称:TelerikAcademy,代码行数:25,代码来源:10-ShortestSequence.cs

示例9: Main

    static void Main()
    {
        Console.WriteLine("Insert expression:");
        string input = Console.ReadLine();
        Stack<char> brackets = new Stack<char>();

        brackets.Push('(');

        while (brackets.Count != 0)
        {
            brackets.Pop();
            foreach (var element in input)
            {
                if (element == '(')
                {
                    brackets.Push(element);
                }
                else if (element == ')')
                {
                    if (brackets.Count == 0)
                    {
                        Console.WriteLine("Incorrect expression!");
                        return;
                    }
                    brackets.Pop();
                }
            }
        }
        if (brackets.Count == 0)
        {
            Console.WriteLine("Correct expression!");
        }
    }
开发者ID:hristobakalov,项目名称:TelerikAcademy,代码行数:33,代码来源:CheckBrackets.cs

示例10: Execute

        public override void Execute(IContext context, Stack<object> stack)
        {
            Arg1.Execute(context, stack);
            var targets = (IEnumerable<IAssociations>)stack.Pop();

            Arg2.Execute(context, stack);
            var sourceAttributeId = Convert.ToInt32(stack.Pop());


            IAttribute sourceAttribute;
            if (!context.Self.TryGetAttributeById(sourceAttributeId, out sourceAttribute))
            {
                return;
                //TODO hier sollte besser ein fehler entstehen, weil sonst fehlende dinge uebersehen werden
                //oder irgednwie loggen zumindest

                //TODO exception type -- code duplication
                throw new Exception(string.Format("Missing attribute {0} for item {1}/{2}", sourceAttributeId, context.Self.TypeName, context.Self.TypeId));
            }

            foreach (var curTarget in targets)
            {
                curTarget.Remove(sourceAttribute);
            }
        }
开发者ID:rischwa,项目名称:eve-fast-fitting-assessment,代码行数:25,代码来源:RemoveModifierExpression.cs

示例11: Execute

        /// <summary>
        /// Execute divison operator and put result into operands stack
        /// </summary>
        /// <param name="operands">stack with operands</param>
        /// <param name="mode">mode to operate in</param>
        /// <returns>true/false if execution went well</returns>
        public override bool Execute(Stack<Operand> operands, CalculatorMode mode)
        {
            try
            {
                // b / a
                Operand a = operands.Pop();
                Operand b = operands.Pop();
                Operand c; // result

                // if we are in programming mode and both operands are integers
                // do a integer division
                if (mode == CalculatorMode.Programming &&
                    a.Value == (Int32)a.Value &&
                    b.Value == (Int32)b.Value)
                {
                    c = new Operand((Int32)b.Value / (Int32)a.Value);
                }
                else
                {
                    c = new Operand(b.Value / a.Value);
                }
                operands.Push(c);
                return true;
            }
            catch (Exception)
            {
                return false;
            }
        }
开发者ID:KonstantinGo,项目名称:Calculator,代码行数:35,代码来源:Div.cs

示例12: Perform

 public void Perform(
     CodeBlock block,
     Stack<DmlObject> stack,
     Dictionary<string, DmlObject> locals,
     DmlObject bullet, DmlSystem system)
 {
     switch (property)
     {
         case DmlTokens.INTRINSIC_DIRECTION:
             ((DmlBullet)bullet.Value).Direction = (Vector2)(stack.Pop().Value);
             break;
         case DmlTokens.INTRINSIC_SPEED:
             ((DmlBullet)bullet.Value).Speed = (double)(stack.Pop().Value);
             break;
         case DmlTokens.INTRINSIC_COLOUR:
             ((DmlBullet)bullet.Value).Colour = (Color)(stack.Pop().Value);
             break;
         case DmlTokens.INTRINSIC_SPRITE:
             string name = (string)(stack.Pop().Value);
             ((DmlBullet)bullet.Value).SetSprite(name.Substring(1, name.Length - 2));
             break;
         default:
             throw new DmlSyntaxError(String.Format("Unknown intrinsic property \"{0}\"", property));
     }
 }
开发者ID:roflwaffl,项目名称:Phosphaze,代码行数:25,代码来源:AssignIntrinsicBulletProperty.cs

示例13: TestStack

        public void TestStack()
        {
            var st = new Stack<int>();
            for (int i = 0; i < 10; i++)
            {
                st.Push(i);
            }

            Assert.AreEqual(st.Top(), 9);

            Assert.AreEqual(st.Pop(), 9);
            Assert.AreEqual(st.Top(), 8);

            while (!st.IsEmpty())
                st.Pop();

            try
            {
                var t = st.Top(); // should raise Exception here
                Assert.IsTrue(false);
            }
            catch (Exception)
            {
                // should be here
            }
        }
开发者ID:BotterVN,项目名称:CodeSnippets,代码行数:26,代码来源:TestList.cs

示例14: Main

    public static void Main()
    {
        Console.WriteLine("Write a sequence of integer numbers separated by space or comma");

        Console.Write("Integers: ");

        string[] userInput = Console.ReadLine().Split(' ', ',');

        Stack<int> sequence = new Stack<int>();

        for (int i = 0; i < userInput.Length; i++)
        {
            sequence.Push(int.Parse(userInput[i]));
        }

        Console.Write("Reversed sequence -> ");
        while (sequence.Count > 0)
        {
            if (sequence.Count == 1)
            {
                Console.Write("{0}", sequence.Pop());
                break;
            }
            Console.Write("{0}, ", sequence.Pop());
        }
        Console.WriteLine();
    }
开发者ID:vassil,项目名称:CSharp,代码行数:27,代码来源:02.ReverseNumbersWithStack.cs

示例15: GetMaxHappiness

 private static int GetMaxHappiness(Stack<string> atTable, List<string> free, Conditions conditions)
 {
     if (free.Count == 1)
     {
         atTable.Push(free.Single());
         var table = new Table(atTable.ToList());
         var totalHappiness = table.CalcTotalHappiness(conditions);
         atTable.Pop();
         return totalHappiness;
     }
     var maxHappiness = 0;
     for (int i = 0; i < free.Count; i++)
     {
         atTable.Push(free[i]);
         free.RemoveAt(i);
         var happiness = GetMaxHappiness(atTable, free, conditions);
         if (happiness > maxHappiness)
         {
             maxHappiness = happiness;
         }
         var person = atTable.Pop();
         free.Insert(i, person);
     }
     return maxHappiness;
 }
开发者ID:navoznov,项目名称:AdventOfCode,代码行数:25,代码来源:Program.cs


注:本文中的Stack.Pop方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。