using System;

//  פעולות שניתן להפעיל על תור מסוג שלמים
//  יצירת תור ריק
    // new Queue<int>()
// הכנסה לתור
    // Insert(int)
// הוצאה מהתור  
    // int Remove()
// האם התור ריק 
    // bool Isempty()
// בדיקה מה האיבר הראשון בתור  
    // int Head()
    
    // נסיון

class Program 
{
  public static void Main (string[] args) 
  {
    Queue<int> q1 = new Queue<int>();
    Console.WriteLine("Empty q /: " + q1); // הדפסת תור ריק
    Console.WriteLine("q1 is empty ? : " + q1.IsEmpty());
    q1.Insert(5);
    q1.Insert(6);
    Console.WriteLine(q1);
    Console.WriteLine("q1 is empty ? : " + q1.IsEmpty());
    q1.Remove();
    Console.WriteLine("after remove: " + q1);
    q1.Insert(7);
    Console.WriteLine(q1);
    
    Console.WriteLine("=============================");
    Console.WriteLine("Examples of methods on Queues:");
    Console.WriteLine("=============================");
    int[] arr = {5,-3,9,5,8,-1};
    Queue<int> q2 = ArrayToQ(arr);
    Console.WriteLine("q2: " + q2);
    Console.WriteLine("number of items in q2: " + Size(q2));
    Console.WriteLine("q2: " + q2);
    Queue<int> q4 = CopyQ(q2);
    Console.WriteLine("q4 - copy of q2: " + q4);
    RemoveItemFromQ(q4,5);
    Console.WriteLine("q4 after removing 5: " + q4);
    
    Queue<int> q3 = CopyPositiveQ(q2);
    Console.WriteLine("q3 copy postive numbers from q2: " + q3);
    Console.WriteLine("q2 : " + q2);
    Queue<int> q5 = CopyPositiveQ2(q2);
    Console.WriteLine("q5 copy postive numbers from q2 , implementation #2: " + q5);
    Console.WriteLine("q2 : " + q2);
    
    ReverseQ(q2);
    Console.WriteLine("q2 reversed (using recurssion): " + q2);
  }
  
  
  // פעולה שמחזירה את מספר האיברים בתור
  public static int Size(Queue<int> q)  
  {
    Queue<int> q1 = new Queue<int>(); // יצירת תור עזר חדש ריק  
    int count = 0;
    while(!q.IsEmpty())
    {
      count++;
      q1.Insert(q.Remove()); // העברה לתור עזר
    }
    while(!q1.IsEmpty()) // שחזור התור המקורי
    {
      q.Insert(q1.Remove());
    }
    return count;
  }
  
  // create queue of int from array of int
  static Queue<int> ArrayToQ(int[] arr)
  {
    Queue<int> q = new Queue<int>();
    for(int i=0;i<arr.Length;i++)
    {
      q.Insert(arr[i]);
    }
    return q;
  }
  
  
  // CopyQ 
  // העתקת תור
  static Queue<int> CopyQ(Queue<int> q)
  {
    Queue<int> retQ = new Queue<int>(); // התור המועתק החדש
    Queue<int> tempQ = new Queue<int>(); // תור לטובת שחזור התור המקורי
    
    while(!q.IsEmpty())
    {
      int n = q.Head();
      retQ.Insert(n);
      tempQ.Insert(n);
      q.Remove();
    }
    // שחזור התור
    while(!tempQ.IsEmpty())
    {
      q.Insert(tempQ.Remove());
    }
    
    return retQ ;
  }
  // CopyQ 
  // העתקת תור פעולה גנרית - מתאימה לכל סוג
  static Queue<T> CopyQ<T>(Queue<T> q)
  {
      Queue<T> q2 = new Queue<T>();
      Queue<T> q3 = new Queue<T>();
      while (!q.IsEmpty())
      {
          T x = q.Remove();
          q2.Insert(x);
          q3.Insert(x);
      }
      while (!q2.IsEmpty())
          q.Insert(q2.Remove());

      return q3;
  }
  
  static void RemoveItemFromQ(Queue<int> q, int x)
  {
    Queue<int> tempQ = new Queue<int>();
    while(!q.IsEmpty())
    {
      if(q.Head() != x)
      {
        tempQ.Insert(q.Head());
      }
      q.Remove();
    }
    while(!tempQ.IsEmpty()) // שחזור התור
    {
      q.Insert(tempQ.Remove());
    }
  }
  
  // מקבלים תור של שלמים
  // מחזירים תור אחר שמכיל רק את המספרים החיוביים
  static Queue<int> CopyPositiveQ(Queue<int> q)
  {
    Queue<int> retQ = new Queue<int>();
    Queue<int> tempQ = new Queue<int>();
    
    while(!q.IsEmpty())
    {
      int n = q.Head();
      if (n > 0)
      {
        retQ.Insert(n);
      }
      tempQ.Insert(q.Remove());
    }
    while(!tempQ.IsEmpty())
    {
      q.Insert(tempQ.Remove());
    }
    
    return retQ ;
  }
  
  // מקבלים תור של שלמים
  // מחזירים תור אחר שמכיל רק את המספרים החיוביים
  static Queue<int> CopyPositiveQ2(Queue<int> q)
  {
    Queue<int> retQ = new Queue<int>();
    Queue<int> tempQ = CopyQ(q);
    
    while(!tempQ.IsEmpty())
    {
      int n = tempQ.Remove();
      if (n > 0)
      {
        retQ.Insert(n);
      }
    }
    return retQ ;
  }
  
    // הופך את סדר האיברים בתור
  // מימוש רקורסיבי
  public static void ReverseQ(Queue<int> q)
  {
    if(!q.IsEmpty())
    {
      int x = q.Remove();
      ReverseQ(q);
      q.Insert(x);
    }
  }
  
  // שיטה נוספת למעבר על תור
  // (מעגלי) מעבר ציקלי 
  public static int CountQ2(Queue<int> q)  
  {
    
    int count = 0;
    q.Insert(-999); // הכנסת איבר "דמה" לתור. חשוב:איבר הדמה חייב להיות כזה שלא ייתכן שנכלל בתור המקורי
    while(q.Head() != -999)
    {
      count++;
      q.Insert(q.Remove()); // העברת האיבר הראשון בתור לסוף התור
    }
    q.Remove(); // הסרת איבר הדמה
    
    return count;
  }
  // מימוש רקורסיבי
  // התור המקורי לא נשמר
  public static int CountQ3(Queue<int> q)  
  {
    if(q.IsEmpty())
      return 0;
    q.Remove();
    return 1+CountQ3(q);
  }
  
} 
by

C Sharp Online Compiler

Write, Run & Share C# code online using OneCompiler's C# online compiler for free. It's one of the robust, feature-rich online compilers for C# language, running on the latest version 8.0. Getting started with the OneCompiler's C# compiler is simple and pretty fast. The editor shows sample boilerplate code when you choose language as C# and start coding.

Read inputs from stdin

OneCompiler's C# online compiler supports stdin and users can give inputs to programs using the STDIN textbox under the I/O tab. Following is a sample program which takes name as input and print your name with hello.

using System;
 
namespace Sample
{
  class Test
    {
      public static void Main(string[] args)
       {
         string name;
         name = Console.ReadLine();
         Console.WriteLine("Hello {0} ", name);
	}
     }
}

About C Sharp

C# is a general purpose object-oriented programming language by Microsoft. Though initially it was developed as part of .net but later it was approved by ECMA and ISO standards.

You can use C# to create variety of applications, like web, windows, mobile, console applications and much more using Visual studio.

Syntax help

Data types

Data TypeDescriptionRangesize
intTo store integers-2,147,483,648 to 2,147,483,6474 bytes
doubleto store large floating point numbers with decimalscan store 15 decimal digits8 bytes
floatto store floating point numbers with decimalscan store upto 7 decimal digits4 bytes
charto store single characters-2 bytes
stringto stores text-2 bytes per character
boolto stores either true or false-1 bit

Variables

Syntax

datatype variable-name = value;

Loops

1. If-Else:

When ever you want to perform a set of operations based on a condition or set of few conditions IF-ELSE is used.

if(conditional-expression) {
   // code
} 
else {
   // code
}

You can also use if-else for nested Ifs and If-Else-If ladder when multiple conditions are to be performed on a single variable.

2. Switch:

Switch is an alternative to If-Else-If ladder.

switch(conditional-expression) {    
case value1:    
 // code    
 break;  // optional  
case value2:    
 // code    
 break;  // optional  
...    
    
default:     
 // code to be executed when all the above cases are not matched;    
} 

3. For:

For loop is used to iterate a set of statements based on a condition.

for(Initialization; Condition; Increment/decrement) {
  // code  
} 

4. While:

While is also used to iterate a set of statements based on a condition. Usually while is preferred when number of iterations are not known in advance.

while(condition) {
 // code 
}

5. Do-While:

Do-while is also used to iterate a set of statements based on a condition. It is mostly used when you need to execute the statements atleast once.

do {
  // code 
} while (condition);

Arrays

Array is a collection of similar data which is stored in continuous memory addresses. Array values can be fetched using index. Index starts from 0 to size-1.

Syntax

data-type[] array-name;

Methods

Method is a set of statements which gets executed only when they are called. Call the method name in the main function to execute the method.

Syntax

static void method-name() 
{
  // code to be executed
}