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); } }
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.
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);
}
}
}
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.
Data Type | Description | Range | size |
---|---|---|---|
int | To store integers | -2,147,483,648 to 2,147,483,647 | 4 bytes |
double | to store large floating point numbers with decimals | can store 15 decimal digits | 8 bytes |
float | to store floating point numbers with decimals | can store upto 7 decimal digits | 4 bytes |
char | to store single characters | - | 2 bytes |
string | to stores text | - | 2 bytes per character |
bool | to stores either true or false | - | 1 bit |
datatype variable-name = value;
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.
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;
}
For loop is used to iterate a set of statements based on a condition.
for(Initialization; Condition; Increment/decrement) {
// code
}
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
}
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);
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.
data-type[] array-name;
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.
static void method-name()
{
// code to be executed
}