当前位置: 首页 > news >正文

哪里有app项目开发汤阴县seo快速排名有哪家好

哪里有app项目开发,汤阴县seo快速排名有哪家好,有口碑的网站建设,政府网站集约化建设进展算法原理 丛待排序的数列中选择一个基准值,通过遍历数列,将数列分成两个子数列:小于基准值数列、大于基准值数列,准确来说还有个子数列:等于基准值即: 算法图解 选出基准元素pivot(可以选择…

算法原理

丛待排序的数列中选择一个基准值,通过遍历数列,将数列分成两个子数列:小于基准值数列、大于基准值数列,准确来说还有个子数列:等于基准值即:
在这里插入图片描述

算法图解

  1. 选出基准元素pivot(可以选择最左侧元素),设置两个指针(Java中可看成是数组索引)left和right,left指向数列最左边的元素,right指向最右侧元素
  2. 进行第一次遍历,先丛right指针开始,让其指向的元素和pivot作比较,大于或等于则指针向左移动一个位置,小于则停止移动,等待left指针移动
  3. 轮到left指针移动,同样先让left指向的元素和pivot做比较,小于或等于则指针向右移动,大于则停止移动
  4. 此时left和right都停止移动,判断left和right是否在同一个位置,否则交换位置元素。
  5. 继续丛2开始,直至left和right相交,将pivot值与left指向的元素进行交换,第一次遍历结束,获得分区指针left。
  6. 再将两个子数列按照1到6的步骤继续执行,直至所有子数列排序完成。
    在这里插入图片描述

算法实现

public class QuickSort {public void sort(int []arr){doSort(arr,0,arr.length-1);}public void doSort(int []arr,int left,int right){if(left >= right){return;}int partitionIndex = partition(arr, left, right);doSort(arr,left,partitionIndex-1);doSort(arr,partitionIndex+1,right);}/*** 右指针先往左移动* @param arr* @param left* @param right* @return*/public int partition(int []arr,int left,int right) {int startIndex = left;int pivot = arr[startIndex];while (left < right) {while (left < right && arr[right] >= pivot) {right--;}while (left < right && arr[left] <= pivot) {left++;}if (left < right) {swap(arr, left, right);}}swap(arr, startIndex, left);return left;}private void swap(int arr[],int i,int j){int temp = arr[i];arr[i] = arr[j];arr[j] = temp;}}

测试

  public static void main(String[] args) {int arr[] = {9, 7, 1991, 27, -1, -10, 0,10,9,8,-1,27,-1, 2, 65, -100};new QuickSort().sort(arr);for (int i = 0; i < arr.length; i++) {System.out.print(arr[i] + "\t");}}

结果

在这里插入图片描述

分区实现2

  /*** 左指针先往右移动* @param arr* @param left* @param right* @return*/public int partition(int []arr,int left,int right){int startIndex = left;int pivot = arr[startIndex];while (left < right) {while (left < right && arr[left] <= pivot) {left++;}while (left < right&&arr[right] >= pivot){right --;}if(left < right){swap(arr,left,right);}}if(arr[left] >= pivot){swap(arr,startIndex,left-1);return left-1;}swap(arr,startIndex,left);return left;}
http://www.ritt.cn/news/25558.html

相关文章:

  • 前端网站开发框架网络营销的职能有哪些
  • 搭建vpn访问国外网站seo快速优化
  • jsp网站开发 英文河南省最新通知
  • 福州网站建设哪家好网站外链购买平台
  • 营销网站建设案例宁波seo在线优化方案公司
  • 新疆模板网站建设整站优化服务
  • 我的世界大盒子怎么做视频网站郑州百度公司地址
  • 用什么做网站比较好温州高端网站建设
  • 网站的首页怎么做郑州粒米seo外包
  • 南宁网站推广经理企业培训课程名称大全
  • 门户网站官网有哪些短视频培训机构排名
  • 手机网站自动适配成都私人网站制作
  • 石家庄网站定制制作搜狗链接提交入口
  • 新疆交通建设行业协会网站长沙线上引流公司
  • 初学者学做网站怎么学百度24小时人工客服电话
  • 国外b2b网站域名百度基木鱼建站
  • 建设营销型网站的优势app推广软件有哪些
  • 树莓派做的网站百度后台登录
  • 网站用户注册页面怎么做seo数据分析
  • 可以在几个 网站备案每日军事新闻
  • 网站建设设计设计公司哪家好seo推广方案怎么做
  • 中国砖瓦招聘求职平台百度seo排名优化是什么
  • 做网站徐州seo是干嘛的
  • 企业营销型网站建设价格最新提升关键词排名软件
  • 网站建设中手机版网络营销seo是什么意思
  • 北京营销型网站建设哪家好站长
  • 晋中路桥建设集团网站广东省新闻
  • 网站logo怎么替换seo建站要求
  • 网站建设设计 飞沐网站目录
  • B2C网站开发功能表推广普通话的意义是什么