怎样排序?

发布网友 发布时间:2022-04-23 08:21

我来回答

2个回答

热心网友 时间:2022-06-18 07:30

冒泡排序是一种简单的排序算法,就地排序。实现原理也很简单:重复地遍历要排序的数列,一次比较两个元素,如果两个元素根据某种排序策略相对位置错误,那么就交换这两个元素的位置。遍历的操作重复进行直到不需要再进行任何交换,也就是说数列已经成为一种有序数列呢。

接下来我们通过图示的方式来说明冒泡排序的过程,以下是第一轮冒泡排序过程:

从上图我们可以看到,一轮冒泡排序过程是这样的:每次冒泡过程都是从数列的第一个元素开始,然后依次和剩余的元素进行比较,若小于相邻元素,则交换两者位置,同时将较大元素作为下一个比较的基准元素,继续将该元素与其相邻的元素进行比较,直到数列的最后一个元素。在具体的实现过程中,我们可以记录当前冒泡排序过程之前,数列中尾部已经排序好的最大元素里最小元素的位置。这样,当前冒泡排序只需要进行到该最小位置即可,减少不必要的比较过程,提高排序效率。在这里贴上维基百科上有关冒泡排序过程图,比较形象:

4.C/C++实现程序代码:

  void bubbleSort(int arr[],int count){
     int i,j,temp,tag;//tag用于记录当前冒泡排序进行比较的终止位置
        tag=count-1;
           for(i=0;i<count-1;i++){
           for(j=0;j<tag;j++){
               if(arr[j]>arr[j+1]){
                   temp=arr[j];
                   arr[j]=arr[j+1];
                   arr[j+1]=temp;
              }
          }
          tag--;//下一轮排序进行比较的终止位置
      }
  }

热心网友 时间:2022-06-18 07:31

如下是java实现的冒泡排序,供参考:

/**
 * 冒泡排序
 * 
 * @author qd
 *
 */
public class Ab {

    public static void main(String[] args) {

        // 待排序数组
        int[] is = { 22, 29, 37, 11, 4, 46 };

        // 控制排序的趟数
        for (int i = 0; i < is.length - 1; i++) {

            // 控制每一趟中的排序方式
            for (int j = 0; j < is.length - 1 - i; j++) {

                int temp = 0;
                if (is[j] > is[j + 1]) {

                    temp = is[j];
                    is[j] = is[j + 1];
                    is[j + 1] = temp;
                }
            }
        }

        // 遍历数组,打印元素
        for (int i = 0; i < is.length; i++) {
            System.out.print(is[i] + " ");
        }
    }
}

运行结果:

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com