The following article provides an outline on Bubble Sort in C#. Bubble sort is a sorting algorithm which is considered to be the simplest algorithm, which places the elements or numbers in a particular order and these elements are eventually put to their sorted proper location in the array.
Bubble sort Algorithm
The basic concept upon which bubble sort works is that an array is taken into consideration. This array is iterated from the first index to the last index. While traversing the array is compared with the adjacent elements and swapped if they are present in the wrong order. This means if the numbers are smaller than the current element at a particular index then they will be swapped. This process is repeated until the array is completely sorted. It takes place in the form of passes.
Let us take into consideration an array of seven random numbers and sort them:
Bubble sort works in the form of passes. These passes take two adjacent numbers at a single time and then compare those two numbers. If the numbers present are said to be N. Then the number of passes required to sort a data set are N – 1. Each pass sorts the data considering those two numbers and reiterates the sequence till all numbers are not sorted in the expected way.
Pass 1:
90 76 45 93 68 13 98
In the first pass the first two numbers are compared. Here it will compare 90 with 76. 90 is greater than 76 hence it will be swapped.
76 90 45 93 68 13 98
Now 90 will be compared with 45. (0 is greater than 45 as well. Hence this will be getting swapped with 45.
76 45 90 93 68 13 98
Now, the numbers 90 and 93 are already in order. They will not be swapped and will remain as it is. This pass will hence be stopped as per the algorithm.
Pass 2:
76 45 90 93 68 13 98
This pass will again start with the first number in the array. This means the sorting will now start from 76. 76 will be compared with 45. 45 being lesser than 76 will be swapped with 76.
45 76 90 93 68 13 98
Now 76 and 90 will be checked. They are already in correct order hence there will be no changes in the array.
In this way the traversing will happen till the end of the array.
Algorithm of Bubble Sort
- BubbleSort(Array : list of sortable items)
- N= Array.Length
- Set Flag := True
- Repeat Steps from 3 to 5 for I = 1 to N-1 while Flag == true
- Set Flag := False
- Set i:=0
- Repeat while i
- (a) If Array[i+1]>Array[i], then:
Swap Array[i] and Array[i+1] Set Flag:= True- (b) Set i :=i+1
- Exit
- (a) If Array[i+1]>Array[i], then:
Examples of Bubble Sort in C#
Given below are the examples:
Example #1
C# program to implement Bubble sort.
Code:
using System; class Bubble { static void bubbleSrt(int []arr) { int num = arr.Length; for (int i = 0; i arr[j + 1]) { // swap tmp and arr[i] int tmp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = tmp; } } /* Printing the array */ static void printIt(int []arr) { int n = arr.Length; for (int i = 0; i <p><strong>Output:</strong></p> <p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/172534826657014.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Bubble Sort in C#" ></p> <p>The program above has a method defined to sort the numbers using Bubble sort. Bubblesort has two for loops which traverse the array and store the number to be swapped in a temporary variable tmp. This tmp value is then swapped with the position where it should be with the help of index j. Another method is used to print the sorted array. Bubble sort makes use of n – 1 passes to sort the array.</p> <p>The Bubble sort can be implemented for descending order as well.</p> <h4 id="Example">Example #2</h4> <p>The C# program to implement Bubble sort in descending order can be as below:</p> <p><strong>Code:</strong></p> <pre class="brush:php;toolbar:false">using System; public class BubbleSrt { public static void Main(string[] args) { int[]arr=new int[10]{23,98,45,12,9,16,65,74,34,29};//Array created with 10 unsorted numbers bubblesort(arr,10); int a; for(a = 0; a a; b--) if (data[b] > data[b-1])//Condition to arrange array in descending order { int temp = data[b]; data[b]=data[b-1]; data[b-1]=temp; } } }
Output:
Here, we are sorting the array in descending order. We have declared an array having ten numbers. After that we are calling the bubblesort function in main program and then printing it in descending order. The bubblesort function here has taken two variables for traversing the array. Here it is taking two for loops and traversing the array and comparing the values present in the array. The condition being data present at index b and index b – 1 will be compared. If the number present at b is greater then it will be swapped. This is being done in the inner for loop. Once it is swapped, it will continue until the end of the array.
Conclusion
Bubble sort is the simplest sorting method. It traverses the entire array and bubble pops the numbers which helps in swapping and bringing the array in correct sequence. It compares two adjacent numbers and pops those as and when they are not in the expected order. This sorting by using C# is very easy and can be done by using basic variables present in the array.
The above is the detailed content of Bubble Sort in C#. For more information, please follow other related articles on the PHP Chinese website!

C# and .NET provide powerful features and an efficient development environment. 1) C# is a modern, object-oriented programming language that combines the power of C and the simplicity of Java. 2) The .NET framework is a platform for building and running applications, supporting multiple programming languages. 3) Classes and objects in C# are the core of object-oriented programming. Classes define data and behaviors, and objects are instances of classes. 4) The garbage collection mechanism of .NET automatically manages memory to simplify the work of developers. 5) C# and .NET provide powerful file operation functions, supporting synchronous and asynchronous programming. 6) Common errors can be solved through debugger, logging and exception handling. 7) Performance optimization and best practices include using StringBuild

.NETFramework is a cross-language, cross-platform development platform that provides a consistent programming model and a powerful runtime environment. 1) It consists of CLR and FCL, which manages memory and threads, and FCL provides pre-built functions. 2) Examples of usage include reading files and LINQ queries. 3) Common errors involve unhandled exceptions and memory leaks, and need to be resolved using debugging tools. 4) Performance optimization can be achieved through asynchronous programming and caching, and maintaining code readability and maintainability is the key.

Reasons for C#.NET to remain lasting attractive include its excellent performance, rich ecosystem, strong community support and cross-platform development capabilities. 1) Excellent performance and is suitable for enterprise-level application and game development; 2) The .NET framework provides a wide range of class libraries and tools to support a variety of development fields; 3) It has an active developer community and rich learning resources; 4) .NETCore realizes cross-platform development and expands application scenarios.

Design patterns in C#.NET include Singleton patterns and dependency injection. 1.Singleton mode ensures that there is only one instance of the class, which is suitable for scenarios where global access points are required, but attention should be paid to thread safety and abuse issues. 2. Dependency injection improves code flexibility and testability by injecting dependencies. It is often used for constructor injection, but it is necessary to avoid excessive use to increase complexity.

C#.NET is widely used in the modern world in the fields of game development, financial services, the Internet of Things and cloud computing. 1) In game development, use C# to program through the Unity engine. 2) In the field of financial services, C#.NET is used to develop high-performance trading systems and data analysis tools. 3) In terms of IoT and cloud computing, C#.NET provides support through Azure services to develop device control logic and data processing.

.NETFrameworkisWindows-centric,while.NETCore/5/6supportscross-platformdevelopment.1).NETFramework,since2002,isidealforWindowsapplicationsbutlimitedincross-platformcapabilities.2).NETCore,from2016,anditsevolutions(.NET5/6)offerbetterperformance,cross-

The C#.NET developer community provides rich resources and support, including: 1. Microsoft's official documents, 2. Community forums such as StackOverflow and Reddit, and 3. Open source projects on GitHub. These resources help developers improve their programming skills from basic learning to advanced applications.

The advantages of C#.NET include: 1) Language features, such as asynchronous programming simplifies development; 2) Performance and reliability, improving efficiency through JIT compilation and garbage collection mechanisms; 3) Cross-platform support, .NETCore expands application scenarios; 4) A wide range of practical applications, with outstanding performance from the Web to desktop and game development.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

WebStorm Mac version
Useful JavaScript development tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SublimeText3 Chinese version
Chinese version, very easy to use

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
