zoukankan      html  css  js  c++  java
  • java排序

    双端扫描交换排序


    public
    void sort(int[] item, int start,int end){ if(start < end){ int head = item[start]; int i = start + 1; int j = end; while(i <= j){ while(i <= j && item[i] < head){//条件满足的话,i一直向右走, 直到条件终止(item[i]大于pro) i ++; } //注意: 这里的大小判断用的是大于等于 while(i <= j && item[j] >= head){//条件满足,j一直向左走, 直到条件终止(item[i]小于pro) j --; } //当i,j停止移动,说明item[i]大于pro, item[j]小于pro, 这个时候交换item[i]和item[j]的值 if(i <= j){//交换i j , 小的在左边,大的在右边 int tem = item[i]; item[i] = item[j]; item[j] = tem; } } //当i大于j的时候,将pro和item[j]交换, 这样就形成了以item[j]为分界点, 左边小于item[j], 右边大于item[j] int tem = item[j]; item[j] = head; item[start] = tem; //快排左边 sort(item,start,j-1); //快排右边 sort(item,j+1,end); } }

    赋值排序

    public void filling(int[] item, int start, int end){
            if(start < end){
                int head = item[start];
                int i = start;
                int j = end;
                while(i < j){
                    while(i < j && item[j] > head){
                        j --;
                    }
                    item[i] = item[j];
                    while(i < j && item[i] <= head){
                        i ++;
                    }
                    item[j] = item[i];
                }
                item[i] = head;
                filling(item,start,i - 1);
                filling(item, i + 1, end);
            }
        }

     参考地址: https://blog.csdn.net/Holmofy/article/details/71168530

  • 相关阅读:
    Android四大组件
    git命令记录
    .net core试水
    记一次NPOI的使用
    上位机开发经验教训总结
    Python爬虫,爬取腾讯漫画实战
    记一次微信小程序的开发
    sql使用cte表达式进行递归查询
    使用百度的webuploader进行附件上传
    Winform文件上传
  • 原文地址:https://www.cnblogs.com/gczmn/p/9929013.html
Copyright © 2011-2022 走看看