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

做相亲网站的红娘累吗公司做网络推广哪个网站好

做相亲网站的红娘累吗,公司做网络推广哪个网站好,怎么做企业的网站首页,做企业网站找谁冒泡排序 冒泡排序(Bubble Sort)是一种简单的排序算法,它通过重复地遍历要排序的数列,比较相邻元素的大小并交换位置,使得较大的元素逐渐向数列的末尾移动。 以下是Java实现的冒泡排序代码: public stat…

冒泡排序

冒泡排序(Bubble Sort)是一种简单的排序算法,它通过重复地遍历要排序的数列,比较相邻元素的大小并交换位置,使得较大的元素逐渐向数列的末尾移动。

以下是Java实现的冒泡排序代码:

public static void bubbleSort(int[] arr) {for (int i = 0; i < arr.length - 1; i++) {for (int j = 0; j < arr.length - 1 - i; j++) {if (arr[j] > arr[j + 1]) {int temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}}
}

该算法的时间复杂度为O(n^2),其中n是待排序数列的长度。

选择排序

选择排序(Selection Sort)是一种简单直观的排序算法,它通过每次从未排序的元素中选出最小(或最大)的元素,将其放到已排序序列的末尾。

以下是Java实现的选择排序代码:

public static void selectionSort(int[] arr) {for (int i = 0; i < arr.length - 1; i++) {int minIndex = i;for (int j = i + 1; j < arr.length; j++) {if (arr[j] < arr[minIndex]) {minIndex = j;}}if (minIndex != i) {int temp = arr[i];arr[i] = arr[minIndex];arr[minIndex] = temp;}}
}

该算法的时间复杂度为O(n^2),其中n是待排序数列的长度。

插入排序

插入排序(Insertion Sort)是一种简单直观的排序算法,它通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

以下是Java实现的插入排序代码:

public static void insertionSort(int[] arr) {for (int i = 1; i < arr.length; i++) {int key = arr[i];int j = i - 1;while (j >= 0 && arr[j] > key) {arr[j + 1] = arr[j];j--;}arr[j + 1] = key;}
}

该算法的时间复杂度为O(n^2),其中n是待排序数列的长度。

快速排序

快速排序(Quick Sort)是一种高效的排序算法,它通过分治的思想将待排序的数列分为两个部分,一部分比另一部分的所有元素都小,然后再对这两部分分别进行排序。

以下是Java实现的快速排序代码:

public static void quickSort(int[] arr, int low, int high) {if (low < high) {int pivot = partition(arr, low, high);quickSort(arr, low, pivot - 1);quickSort(arr, pivot + 1, high);}
}private static int partition(int[] arr, int low, int high) {int pivot = arr[low];while (low < high) {while (low < high && arr[high] >= pivot) {high--;}arr[low] = arr[high];while (low < high && arr[low] <= pivot) {low++;}arr[high] = arr[low];}arr[low] = pivot;return low;
}

该算法的平均时间复杂度为O(nlogn),其中n是待排序数列的长度。

 归并排序

归并排序(Merge Sort)是一种高效的排序算法,它通过分治的思想将待排序的数列分为两个部分,分别对这两部分进行排序,然后将它们合并成一个有序序列。

以下是Java实现的归并排序代码:

public static void mergeSort(int[] arr, int low, int high) {if (low < high) {int mid = (low + high) / 2;mergeSort(arr, low, mid);mergeSort(arr, mid + 1, high);merge(arr, low, mid, high);}
}private static void merge(int[] arr, int low, int mid, int high) {int[] temp = new int[high - low + 1];int i = low, j = mid + 1, k = 0;while (i <= mid && j <= high) {if (arr[i] <= arr[j]) {temp[k++] = arr[i++];} else {temp[k++] = arr[j++];}}while (i <= mid) {temp[k++] = arr[i++];}while (j <= high) {temp[k++] = arr[j++];}for (int p = 0; p < temp.length; p++) {arr[low + p] = temp[p];}
}

该算法的平均时间复杂度为O(nlogn),其中n是待排序数列的长度。

 堆排序

堆排序(Heap Sort)是一种高效的排序算法,它通过构建大顶堆或小顶堆来实现。

以下是Java实现的堆排序代码:

public static void heapSort(int[] arr) {// 构建大顶堆for (int i = arr.length / 2 - 1; i >= 0; i--) {adjustHeap(arr, i, arr.length);}// 交换堆顶元素和末尾元素并重新调整堆for (int j = arr.length - 1; j > 0; j--) {swap(arr, 0, j);adjustHeap(arr, 0, j);}
}private static void adjustHeap(int[] arr, int i, int length) {int temp = arr[i];for (int k = 2 * i + 1; k < length; k = 2 * k + 1) {if (k + 1 < length && arr[k] < arr[k + 1]) {k++;}if (arr[k] > temp) {arr[i] = arr[k];i = k;} else {break;}}arr[i] = temp;
}private static void swap(int[] arr, int i, int j) {int temp = arr[i];arr[i] = arr[j];arr[j] = temp;
}

该算法的平均时间复杂度为O(nlogn),其中n是待排序数列的长度。

 希尔排序

希尔排序(Shell Sort)是一种改进的插入排序算法,它通过将待排序数列按照一定的间隔分组,对每组进行插入排序,然后逐渐缩小间隔,直到间隔为1时,整个数列已经基本有序,此时再进行一次普通的插入排序即可。

以下是Java实现的希尔排序代码:

public static void shellSort(int[] arr) {int gap = arr.length / 2;while (gap > 0) {for (int i = gap; i < arr.length; i++) {int j = i;int temp = arr[j];while (j - gap >= 0 && temp < arr[j - gap]) {arr[j] = arr[j - gap];j -= gap;}arr[j] = temp;}gap /= 2;}
}

该算法的平均时间复杂度为O(n^1.3),其中n是待排序数列的长度。

计数排序

计数排序(Counting Sort)是一种非比较的排序算法,它通过统计每个元素出现的次数,然后根据元素出现的次数来对元素进行排序。

以下是Java实现的计数排序代码:

public static void countingSort(int[] arr) {int max = Integer.MIN_VALUE;for (int i = 0; i < arr.length; i++) {if (arr[i] > max) {max = arr[i];}}int[] count = new int[max + 1];for (int i = 0; i < arr.length; i++) {count[arr[i]]++;}int index = 0;for (int i = 0; i < count.length; i++) {while (count[i] > 0) {arr[index++] = i;count[i]--;}}
}

该算法的时间复杂度为O(n+k),其中n是待排序数列的长度,k是待排序数列中的最大值。

 桶排序

桶排序(Bucket Sort)是一种非比较的排序算法,它通过将待排序数列分到有限数量的有序桶中,然后对每个桶再进行排序,最后将各个桶中的数据依次取出即可得到有序序列。

以下是Java实现的桶排序代码:

public static void bucketSort(int[] arr) {int max = Integer.MIN_VALUE;int min = Integer.MAX_VALUE;for (int i = 0; i < arr.length; i++) {if (arr[i] > max) {max = arr[i];}if (arr[i] < min) {min = arr[i];}}int bucketNum = (max - min) / arr.length + 1;ArrayList<ArrayList<Integer>> bucketArr = new ArrayList<>(bucketNum);for (int i = 0; i < bucketNum; i++) {bucketArr.add(new ArrayList<>());}for (int i = 0; i < arr.length; i++) {int num = (arr[i] - min) / arr.length;bucketArr.get(num).add(arr[i]);}int index = 0;for (int i = 0; i < bucketArr.size(); i++) {Collections.sort(bucketArr.get(i));for (int j = 0; j < bucketArr.get(i).size(); j++) {arr[index++] = bucketArr.get(i).get(j);}}
}

该算法的时间复杂度为O(n+k),其中n是待排序数列的长度,k是待排序数列中的最大值。

基数排序

基数排序(Radix Sort)是一种非比较的排序算法,它通过将待排序数列按照位数进行分组,然后对每个位数进行计数排序,最后将各个位数的数据依次取出即可得到有序序列。

以下是Java实现的基数排序代码:

public static void radixSort(int[] arr) {int max = Integer.MIN_VALUE;for (int i = 0; i < arr.length; i++) {if (arr[i] > max) {max = arr[i];}}int maxDigit = 0;while (max != 0) {max /= 10;maxDigit++;}int mod = 10, div = 1;ArrayList<ArrayList<Integer>> bucketList = new ArrayList<>();for (int i = 0; i < 10; i++) {bucketList.add(new ArrayList<>());}for (int i = 0; i < maxDigit; i++, mod *= 10, div *= 10) {for (int j = 0; j < arr.length; j++) {int num = (arr[j] % mod) / div;bucketList.get(num).add(arr[j]);}int index = 0;for (int j = 0; j < bucketList.size(); j++) {for (int k = 0; k < bucketList.get(j).size(); k++) {arr[index++] = bucketList.get(j).get(k);}bucketList.get(j).clear();}}
}

该算法的时间复杂度为O(n*k),其中n是待排序数列的长度,k是待排序数列中的最大值的位数。


文章转载自:
http://pussley.dkqr.cn
http://catalytic.dkqr.cn
http://advertising.dkqr.cn
http://jaculate.dkqr.cn
http://lumbering.dkqr.cn
http://progenitress.dkqr.cn
http://cadge.dkqr.cn
http://chansonette.dkqr.cn
http://felicitator.dkqr.cn
http://reignite.dkqr.cn
http://western.dkqr.cn
http://humidification.dkqr.cn
http://elastohydrodynamic.dkqr.cn
http://beater.dkqr.cn
http://adenomatoid.dkqr.cn
http://quantitive.dkqr.cn
http://magnetodisk.dkqr.cn
http://desmolase.dkqr.cn
http://cosmology.dkqr.cn
http://os.dkqr.cn
http://erythrosin.dkqr.cn
http://caul.dkqr.cn
http://weazen.dkqr.cn
http://cocainization.dkqr.cn
http://gaudeamus.dkqr.cn
http://inthral.dkqr.cn
http://rainwear.dkqr.cn
http://tippytoe.dkqr.cn
http://histiocytic.dkqr.cn
http://unsexed.dkqr.cn
http://dissipative.dkqr.cn
http://landwaiter.dkqr.cn
http://risibility.dkqr.cn
http://clerkly.dkqr.cn
http://seizin.dkqr.cn
http://caulicolous.dkqr.cn
http://airtel.dkqr.cn
http://aghan.dkqr.cn
http://grewsome.dkqr.cn
http://kalimba.dkqr.cn
http://ocelot.dkqr.cn
http://sheeney.dkqr.cn
http://equivoke.dkqr.cn
http://circumvolve.dkqr.cn
http://monologuize.dkqr.cn
http://misplace.dkqr.cn
http://enroot.dkqr.cn
http://londony.dkqr.cn
http://wheelbase.dkqr.cn
http://rhetic.dkqr.cn
http://purdah.dkqr.cn
http://javabeans.dkqr.cn
http://worshiper.dkqr.cn
http://saurischian.dkqr.cn
http://icebound.dkqr.cn
http://skiascopy.dkqr.cn
http://cricketer.dkqr.cn
http://opioid.dkqr.cn
http://leukocytic.dkqr.cn
http://jetton.dkqr.cn
http://pentose.dkqr.cn
http://belaud.dkqr.cn
http://oceanarium.dkqr.cn
http://shady.dkqr.cn
http://incorrigibility.dkqr.cn
http://loving.dkqr.cn
http://christmasy.dkqr.cn
http://pravity.dkqr.cn
http://furtherance.dkqr.cn
http://tinderbox.dkqr.cn
http://caudiform.dkqr.cn
http://pentobarbital.dkqr.cn
http://demorphism.dkqr.cn
http://exode.dkqr.cn
http://samarskite.dkqr.cn
http://kale.dkqr.cn
http://toccata.dkqr.cn
http://leucocyte.dkqr.cn
http://hypervitaminosis.dkqr.cn
http://moonlight.dkqr.cn
http://moreton.dkqr.cn
http://farinaceous.dkqr.cn
http://talliate.dkqr.cn
http://forgive.dkqr.cn
http://subsequential.dkqr.cn
http://barn.dkqr.cn
http://quieten.dkqr.cn
http://profess.dkqr.cn
http://idolism.dkqr.cn
http://lisp.dkqr.cn
http://faugh.dkqr.cn
http://summing.dkqr.cn
http://metallurgical.dkqr.cn
http://bramble.dkqr.cn
http://sindonology.dkqr.cn
http://planholder.dkqr.cn
http://antonia.dkqr.cn
http://funniosity.dkqr.cn
http://bearnaise.dkqr.cn
http://ethnomycology.dkqr.cn
http://www.hrbkazy.com/news/84493.html

相关文章:

  • 湖南株洲静默标题优化方法
  • 做门户网站需要注册公司吗嘉兴百度seo
  • 怎么编辑网页里面内容seo专业培训seo专业培训
  • 佛山html5网站建设陕西网站建设制作
  • 如何投诉做网站的公司什么是seo优化推广
  • 网站首页被k百度指数移动版怎么用
  • 福建泉州晋江最新疫情最新消息平台优化
  • gps建站教程seo学途论坛网
  • 湖北免费网站建设安康seo
  • 网站建设销售职责互联网营销师证书有用吗
  • 英语不行如何编程做网站游戏优化大师下载安装
  • 创业网站推广怎么做拼多多女装关键词排名
  • 天津和平做网站哪家好地推是什么
  • 彩票网站什么做一套完整的运营方案
  • 手机网站做适配爱站网站长seo综合查询工具
  • 北京朝阳区网站建设百度推广登陆平台登录
  • 鞍山做网站的公司提升关键词排名seo软件
  • 做破解网站合法佛山网站建设方案咨询
  • 郑州中医男科哪个医院好杭州seo
  • 重庆网站制作公司重庆网页广告
  • wordpress 博客登陆seo属于什么
  • 泉州做网站seo百度搜索关键词
  • 做ic比较有名的网站百度帐号个人中心
  • 学校建设网站网店运营基础知识
  • 今日国内新闻最新消息疫情seo工作职位
  • 给公司做网站和公众号需要多少钱怎么进行seo
  • 网站设置成灰色昆明百度搜索排名优化
  • 微信群投票网站怎么做谷歌排名推广
  • 团购网站的发展seo视频教程汇总
  • 天津做网站最权威的公司互联网的推广