在前面我们学习了for循环,这里我们就运用前面学习的for循环,来实现一个冒泡排序的操作。通常情况下,冒泡排序都是进行从小到大的排序。
下面是我实现的核心源代码:
int[] array_01=new int[10];
Random random_01=new Random();
//开始创建随机的数列
Console.WriteLine("开始输出随机数列:");
for(int i=0;i<array_01.Length;i++)
{
array_01[i]=random_01.Next(1,101);
}
//输出一遍随机的数列
for(int i=0;i<array_01.Length;i++)
{
Console.Write(array_01[i]+"\t");
}
//开始冒泡排序
//比如:10、9、8、7、6、5、4、3、2、1进行从左到右的顺序排列,左边为最小数,右边为最大数
//外层循环代表的是:准备确定的数的索引
for(int i=0;i<=array_01.Length-1;i++)
{
//内层循环代表的是:确定一个数,需要交换的次数
for(int j=1;j<=array_01.Length-1-i;j++)
{
//进行比较,以确定是否要进行交换
if(array_01[i]>array_01[i+j])
{
int temp;
temp=array_01[i];
array_01[i]=array_01[i+j];
array_01[i+j]=temp;
}
}
}
Console.WriteLine("比较的结果为:");
//输出比较的结果
for(int i=0;i<=array_01.Length-1;i++)
{
Console.Write(array_01[i]+"\t");
}
热门评论
比较的是i跟i+1,好像不是i+j