A stack class for characters. : Your Stack « Data Structure « C# / CSharp Tutorial

Home
C# / CSharp Tutorial
1.Language Basics
2.Data Type
3.Operator
4.Statement
5.String
6.struct
7.Class
8.Operator Overload
9.delegate
10.Attribute
11.Data Structure
12.Assembly
13.Date Time
14.Development
15.File Directory Stream
16.Preprocessing Directives
17.Regular Expression
18.Generic
19.Reflection
20.Thread
21.I18N Internationalization
22.LINQ
23.GUI Windows Forms
24.Windows Presentation Foundation
25.Windows Communication Foundation
26.Workflow
27.2D
28.Design Patterns
29.Windows
30.XML
31.XML LINQ
32.ADO.Net
33.Network
34.Directory Services
35.Security
36.unsafe
C# / C Sharp
C# / C Sharp by API
C# / CSharp Open Source
C# / CSharp Tutorial » Data Structure » Your Stack 
11.40.1.A stack class for characters.
using System;  
  
class Stack {   
  char[] stck; // holds the stack  
  int tos;     // index of the top of the stack  
   
  public Stack(int size) {   
    stck = new char[size]// allocate memory for stack   
    tos = 0;   
  }   
  
  public void push(char ch) {   
    if(tos==stck.Length) {   
      Console.WriteLine(" -- Stack is full.");   
      return;   
    }   
       
    stck[tos= ch;  
    tos++;  
  }   
   
  public char pop() {   
    if(tos==0) {   
      Console.WriteLine(" -- Stack is empty.");   
      return (char0;    
    }   
     
    tos--;   
    return stck[tos];   
  
 
  public bool full() { 
    return tos==stck.Length;    
  
 
  public bool empty() { 
    return tos==0
  
 
  public int capacity() { 
    return stck.Length; 
  
 
  public int getNum() { 
    return tos; 
  
}  

class MainClass {   
  public static void Main() {   
    Stack stk1 = new Stack(10);   
    Stack stk2 = new Stack(10);   
    Stack stk3 = new Stack(10);   
    char ch;   
    int i;   
   
    Console.WriteLine("Push A through J onto stk1.")
    for(i=0; !stk1.full(); i++)   
      stk1.push((char) ('A' + i));   
  
    if(stk1.full()) 
       Console.WriteLine("stk1 is full.")
 
    Console.Write("Contents of stk1: ");   
    while!stk1.empty() ) {    
      ch = stk1.pop();   
      Console.Write(ch);   
    }   
   
    Console.WriteLine();   
 
    if(stk1.empty()) 
       Console.WriteLine("stk1 is empty.\n")
   
    Console.WriteLine("Again push A through J onto stk1.")
    for(i=0; !stk1.full(); i++)   
      stk1.push((char) ('A' + i));   
 
    Console.WriteLine("Now, pop chars from stk1 and push " 
                      "them onto stk2.")
    while!stk1.empty() ) {    
      ch = stk1.pop();   
      stk2.push(ch)
    }   
 
    Console.Write("Contents of stk2: ");   
    while!stk2.empty() ) {    
      ch = stk2.pop();   
      Console.Write(ch);   
    }   
 
 
    Console.WriteLine("Capacity of stk2: " + stk2.capacity())
    Console.WriteLine("Number of objects in stk2: " 
                      stk2.getNum())
    
  }   
}
Push A through J onto stk1.
stk1 is full.
Contents of stk1: JIHGFEDCBA
stk1 is empty.

Again push A through J onto stk1.
Now, pop chars from stk1 and push them onto stk2.
Contents of stk2: ABCDEFGHIJCapacity of stk2: 10
Number of objects in stk2: 0
11.40.Your Stack
11.40.1.A stack class for characters.
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.