C#开发排序算法详解

开发 后端 算法
这里介绍C#开发排序算法,对想提高C#语言编程能力的朋友,我们可以互相探讨一下。如:下面的程序,并没有实现多态,来帮它实现一下。

C#语言还是比较常见的东西,这里我们主要介绍C#开发排序算法,包括介绍冒泡排序、选择排序、插入排序、希尔排序等方面。

冒泡排序

学语言要花大力气学数据结构和算法。

using System;  
 
namespace BubbleSorter  
{  
public class BubbleSorter  
{  
public void Sort(int [] list)  
{  
int i,j,temp;  
bool done=false;  
j=1;  
while((j<list.Length)&&(!done))  
{  
done=true;  
for(i=0;i<list.Length-j;i++)  
{  
if(list[i]>list[i+1])  
{  
done=false;  
temp=list[i];  
list[i]=list[i+1];  
list[i+1]=temp;  
}  
}  
j++;  
}  
 
}  
}  
public class MainClass  
{  
public static void Main()  
{  
int[] iArrary=new int[]{1,5,13,6,10,55,99,2,87,12,34,75,33,47};  
BubbleSorter sh=new BubbleSorter();  
sh.Sort(iArrary);  
for(int m=0;m<iArrary.Length;m++)  
Console.Write("{0} ",iArrary[m]);  
Console.WriteLine();  
}  
}  
}  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.

选择排序

本人用了C#开发排序算法。希望能为C#语言的学习者带来一些益处。不要忘了,学语言要花大力气学数据结构和算法。

using System;  
 
namespace SelectionSorter  
{  
public class SelectionSorter  
{  
private int min;  
public void Sort(int [] list)  
{  
for(int i=0;i<list.Length-1;i++)  
{  
min=i;  
for(int j=i+1;j<list.Length;j++)  
{  
if(list[j]<list[min])  
min=j;  
}  
int t=list[min];  
list[min]=list[i];  
list[i]=t;  
}  
 
}  
}  
public class MainClass  
{  
public static void Main()  
{  
int[] iArrary=new int[]{1,5,3,6,10,55,9,2,87,12,34,75,33,47};  
SelectionSorter ss=new SelectionSorter();  
ss.Sort(iArrary);  
for(int m=0;m<iArrary.Length;m++)  
Console.Write("{0} ",iArrary[m]);  
Console.WriteLine();  
 
}  
}  
}  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.

插入排序

插入排序算法。对想提高C#语言编程能力的朋友,我们可以互相探讨一下。如:下面的程序,并没有实现多态,来,帮它实现一下。

using System;  
 
namespace InsertionSorter  
{  
public class InsertionSorter  
{  
public void Sort(int [] list)  
{  
for(int i=1;i<list.Length;i++)  
{  
int t=list[i];  
int j=i;  
while((j>0)&&(list[j-1]>t))  
{  
list[j]=list[j-1];  
--j;  
}  
list[j]=t;  
}  
 
}  
}  
public class MainClass  
{  
public static void Main()  
{  
int[] iArrary=new int[]{1,13,3,6,10,55,98,2,87,12,34,75,33,47};  
InsertionSorter ii=new InsertionSorter();  
ii.Sort(iArrary);  
for(int m=0;m<iArrary.Length;m++)  
Console.Write("{0}",iArrary[m]);  
Console.WriteLine();  
}  
}  
}  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.

希尔排序

希尔排序是将组分段,进行插入排序. 对想提高C#语言编程能力的朋友,我们可以互相探讨一下。如:下面的程序,并没有实现多态,来,帮它实现一下。

using System;  
 
namespace ShellSorter  
{  
public class ShellSorter  
{  
public void Sort(int [] list)  
{  
int inc;  
for(inc=1;inc<=list.Length/9;inc=3*inc+1);  
for(;inc>0;inc/=3)  
{  
for(int i=inc+1;i<=list.Length;i+=inc)  
{  
int t=list[i-1];  
int j=i;  
while((j>inc)&&(list[j-inc-1]>t))  
{  
list[j-1]=list[j-inc-1];  
j-=inc;  
}  
list[j-1]=t;  
}  
}  
}  
}  
public class MainClass  
{  
public static void Main()  
{  
int[] iArrary=new int[]{1,5,13,6,10,55,99,2,87,12,34,75,33,47};  
ShellSorter sh=new ShellSorter();  
sh.Sort(iArrary);  
for(int m=0;m<iArrary.Length;m++)  
Console.Write("{0} ",iArrary[m]);  
Console.WriteLine();  
}  
}  
}  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.

以上介绍C#开发排序算法

【编辑推荐】

  1. C#使用sqlserver存储浅析
  2. 由C++转向C#简单介绍
  3. C# oledbconnection方法浅谈
  4. 数据库常用C#代码概述
  5. C#调用ImOK学习笔记
责任编辑:佚名 来源: IT168
相关推荐

2009-09-10 16:30:11

C#排序函数

2023-10-09 07:11:03

排序算法序列

2009-08-11 09:19:52

C#选择排序C#算法

2009-09-03 14:55:56

C#实现DataGri

2009-08-03 17:38:12

排序算法C#数据结构

2009-08-26 18:14:11

C#排序算法

2009-09-16 13:05:32

C#组件开发

2009-09-08 17:20:01

C#排序算法

2023-10-10 08:00:07

2009-08-31 09:41:05

C#反射静态方法开发

2009-08-25 17:02:20

C#串口操作

2009-09-07 06:18:57

C#窗体设计器

2009-08-10 16:19:37

C#冒泡排序

2009-08-14 17:09:48

C#引用类型

2009-09-07 16:13:56

C# MessageB

2009-08-24 11:23:41

C# TimeLabe

2009-09-01 16:07:04

C#命名规约

2009-07-30 18:20:21

C#继承

2009-11-20 09:10:21

C#开发环境

2017-11-22 14:20:07

前端JavaScript排序算法
点赞
收藏

51CTO技术栈公众号