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


C# Stack.push方法代码示例

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


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

示例1: SortStack

        public static void SortStack(Stack s)
        {
            Stack helper = new Stack();

            helper.push(s.pop());
            while (true)
            {
                if (helper.peek() < s.peek())
                {
                    helper.push(s.pop());
                }
                if (s.getSize() == 0)
                {
                    break;
                }
                double loop = s.pop();
                while (loop < helper.peek())
                {
                    s.push(helper.pop());
                }
                helper.push(loop);
            }

            while (helper.getSize() != 0)
            {
                s.push(helper.pop());
            }
        }
开发者ID:Sanqiang,项目名称:Algorithm-Win,代码行数:28,代码来源:CC3_6.cs

示例2: evaluatepostfixexp

 public void evaluatepostfixexp(string s)
 {
     Stack stack=new Stack(s.Length);
     char[] carr=s.ToCharArray();
     foreach(char c in carr)
     {
         if(isDigit(c))
         {
             stack.push(c-'0');
             Console.WriteLine(stack.peek());
         }
         else
         {
             int a =stack.pop();
             int b=stack.pop();
             switch(c)
             {
                 case '+':stack.push(a+b);break;
                 case '-':stack.push(a-b);break;
                 case '*':stack.push(a*b);break;
                 case '/':stack.push(a/b);break;
             }
         }
     }
     Console.WriteLine(stack.peek());
 }
开发者ID:shailesh2010,项目名称:Practise-DataStructure-and-Algorithm-Programs,代码行数:26,代码来源:stack.cs

示例3: Main

 static void Main()
 {
     Stack s=new Stack();
     s.push(1);
     s.push(2);
     s.push(3);
     s.pop();
     s.pop();
     s.pop();
     s.pop();
 }
开发者ID:shailesh2010,项目名称:Practise-DataStructure-and-Algorithm-Programs,代码行数:11,代码来源:stackll.cs

示例4: Main

        public static void Main(string[] args)
        {
            int M = 5;
            MinPQ<int> pq = new MinPQ<int>(M + 1);

            //StreamReader fs = new StreamReader("tinyW.txt");
            //StreamReader fs = new StreamReader("tinyT.txt");
            //StreamReader fs = new StreamReader("largeW.txt");
            StreamReader fs = new StreamReader("largeT.txt");
            string line;
            while (!fs.EndOfStream)
            {
                line = fs.ReadLine();
                pq.insert(int.Parse(line));

                // eliminam valoarea minima din coada cu prioritate daca sunt M+1 elemente in coada
                if (pq.size() > M)
                    pq.delMin();
            } // cele mai mari M elemente sunt in coada

            // afisam elementele din coada cu prioritate in ordine inversa
            Stack<int> stack = new Stack<int>();
            foreach (var item in pq)
                stack.push(item);

            foreach (var item in stack)
            {
                Console.WriteLine(item);
            }
        }
开发者ID:IonicaBizauKitchen,项目名称:ASD2015,代码行数:30,代码来源:TopM.cs

示例5: Main

        static void Main(string[] args)
        {
            // Print the top M lines in the input stream.
            Console.Write("Write Lenth : ");
            int M = int.Parse(Console.ReadLine());
            Console.Write("Write Del max(True) or min(False) : ");
            bool b = false;
            bool.TryParse(Console.ReadLine(),out b);

            PriorityQueue<int> pq = new PriorityQueue<int>(M,b);

            Console.WriteLine("Insert Queue : ");
            for(int i=0;i<M;i++)
                pq.Insert(int.Parse(Console.ReadLine()));

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

            while (!pq.isEmpty())
                stack.push(pq.Del());

            Console.WriteLine("\n\t OutPut Stack");
            while(!stack.isEmpty())
                Console.WriteLine(stack.pull());

            Console.ReadKey();
        }
开发者ID:kaplunov93,项目名称:Algorithms,代码行数:26,代码来源:Program.cs

示例6: Main

        static void Main(string[] args)
        {
            Stack<int> stack = new Stack<int>();

            stack.push(5);
            stack.push(3);
            stack.push(2);
            stack.push(6);
            stack.push(7);

            stack = Sort(stack);

            while (!stack.isEmpty()) {
                Console.WriteLine(stack.pop());
            }
        }
开发者ID:yellowheartsue,项目名称:cc189_cSharp,代码行数:16,代码来源:Program.cs

示例7: Sort

        //O(n^2) time, O(n) space
        static Stack<int> Sort(Stack<int> stack)
        {
            Stack<int> stack2 = new Stack<int>();

            while (!stack.isEmpty()) {
                int temp = stack.pop();
                while ((!stack2.isEmpty()) && (temp < stack2.peek()))
                {
                    stack.push(stack2.pop());
                }
                stack2.push(temp);
            }

            while (!stack2.isEmpty())
                stack.push(stack2.pop());

            return stack;
        }
开发者ID:yellowheartsue,项目名称:cc189_cSharp,代码行数:19,代码来源:Program.cs

示例8: move

 public void move(int n, Stack destination, Stack loop, Stack original, bool first = true)
 {
     if (n==0)
     {
         return;
     }
     move(n - 1, loop, destination, original);
     destination.push(original.pop());
     move(n - 1, destination, original, loop);
 }
开发者ID:Sanqiang,项目名称:Algorithm-Win,代码行数:10,代码来源:CC3_4.cs

示例9: Main

 static void Main()
 {
     // Console.WriteLine("Enter string");
     // string s=Console.ReadLine();
     // Stack s1=new Stack(s.Length);
     // s=s1.reverse(s);
     // Console.WriteLine(s);
     Stack s=new Stack(5);
     s.push('a');
     s.push('b');
     s.push('c');
     s.push('d');
     s.push('e');
     Console.WriteLine(s.peek());
     s.stackReverse();
     Console.WriteLine(s.pop());
     Console.WriteLine(s.pop());
     Console.WriteLine(s.pop());
     Console.WriteLine(s.pop());
 }
开发者ID:shailesh2010,项目名称:Practise-DataStructure-and-Algorithm-Programs,代码行数:20,代码来源:reversestack.cs

示例10: Main

        public static void Main(string[] args)
        {
            Stack<int> st = new Stack<int>(3);

            for (int i = 0; i < 10; i++)
                st.push(i);

            while (!st.isEmpty())
            {
                Console.WriteLine(st.pop());
            }
        }
开发者ID:IonicaBizauKitchen,项目名称:ASD2015,代码行数:12,代码来源:StackClient.cs

示例11: Main

        static void Main(string[] args)
        {
            string exp = "( 1 + ( ( 2 + 3 ) * ( 4 * 5 ) ) )";
            string[] tokens = exp.Split(' ');

            Stack<string> operatori = new Stack<string>();
            Stack<double> operanzi = new Stack<double>();

            foreach (var item in tokens)
            {
                if (item == "(")
                    ;
                else if (item == "+" || item == "-" || item == "*" || item == "/")
                        operatori.push(item);
                else if (item == ")")
                    {
                        string op = operatori.pop();
                        double v = operanzi.pop();
                        switch (op)
                        {
                            case "+":
                                v = operanzi.pop() + v;
                                break;
                            case "-":
                                v = operanzi.pop() - v;
                                break;
                            case "/":
                                v = operanzi.pop() / v;
                                break;
                            case "*":
                                v = operanzi.pop() * v;
                                break;
                        }
                        operanzi.push(v);
                    }
                else
                    operanzi.push(double.Parse(item));
            }
            Console.WriteLine("Valoarea expresiei este: {0}", operanzi.pop());
        }
开发者ID:IonicaBizauKitchen,项目名称:ASD2015,代码行数:40,代码来源:EvaluareExpresie.cs

示例12: push

 public void push(int value)
 {
     Stack<int> lastStack = getLastStack();
     if (lastStack != null && !lastStack.isFull())
     {
         lastStack.push(value);
     }
     else {
         Stack<int> stack = new Stack<int>(capacity);
         stack.push(value);
         stacks.Add(stack);
     }
 }
开发者ID:yellowheartsue,项目名称:cc189_cSharp,代码行数:13,代码来源:SetOfStack.cs

示例13: SortStackV5

 public static Stack SortStackV5(Stack s)
 {
     Stack n = new Stack();
     while (s.getSize() != 0)
     {
         double tmp = s.pop();
         while (n.getSize()!=0&&n.peek()<tmp)
         {
             s.push(n.pop());
         }
         n.push(tmp);
     }
     return n;
 }
开发者ID:Sanqiang,项目名称:Algorithm-Win,代码行数:14,代码来源:CC3_6.cs

示例14: Main

    public static void Main()
    {
        Stack s = new Stack();
        Console.Write("Stack is created\n");

        s.push(10); s.push(3); s.push(11); s.push(7);
        s.display();

        int i = s.pop();
        Console.Write("\nJust popped {0}", i);
        s.display();

        int[] search = { 2, 3 };

        foreach(int cur in search)
        {
            if (s.isMember(cur))
            {
                Console.Write("\n{0} is in the stack", cur);
            }
            else
            {
                Console.Write("\n{0} is not in the stack", cur);
            }
        }
    }
开发者ID:C12331591,项目名称:College-Work,代码行数:26,代码来源:StackArr.cs

示例15: iterativeDF

    public void iterativeDF(int s)
    {
        Stack S = new Stack();

        id = 0;

        for (int v = 1; v < V + 1; ++v)
        {
            visited[v] = 0;
        }

        S.push(s);

        int prev = 0;

        while (!S.isEmpty())
        {
            int v = S.pop();

            if (visited[v] == 0)
            {
                visited[v] = ++id;
                Console.WriteLine("Visited vertex {0} along edge {1} - {0}", v, prev);

                Node cur = adj[v];

                while (cur != z)
                {
                    int u = cur.vert;

                    if (visited[u] == 0)
                    {
                        S.push(u);
                    }

                    prev = v;
                    cur = cur.next;
                }
            }
        }
    }
开发者ID:C12331591,项目名称:College-Work,代码行数:41,代码来源:GraphLists.cs


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