用java语言写希尔排序

时间: 2023-02-10 15:19:21 浏览: 77
好的,我可以为您提供一个 Java 语言实现的希尔排序代码。 希尔排序是一种插入排序算法,是将数组分割成若干小块然后进行排序,在每一轮排序中,都会将相距一定距离的元素两两交换,这样就可以将数组中更大的元素往前移动。当距离逐渐减小到 1 时,整个数组就已经排好序了。 这是一个 Java 实现的希尔排序代码: ``` public static void shellSort(int[] array) { int gap = array.length / 2; while (gap > 0) { for (int i = gap; i < array.length; i++) { int temp = array[i]; int j = i; while (j >= gap && array[j - gap] > temp) { array[j] = array[j - gap]; j -= gap; } array[j] = temp; } gap /= 2; } } ``` 希尔排序时间复杂度为 O(n^1.3),是一种较快的排序算法。
相关问题

用java写常见排序算法

常见的排序算法有冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序、堆排序等。以下是用 Java 语言实现的一些排序算法: 1. 冒泡排序 ``` public static void bubbleSort(int[] arr) { for (int i = 0; i < arr.length - 1; i++) { for (int j = 0; j < arr.length - i - 1; j++) { if (arr[j] > arr[j + 1]) { int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } ``` 2. 选择排序 ``` 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; } } int temp = arr[i]; arr[i] = arr[minIndex]; arr[minIndex] = temp; } } ``` 3. 插入排序 ``` public static void insertionSort(int[] arr) { for (int i = 1; i < arr.length; i++) { int j = i; while (j > 0 && arr[j] < arr[j - 1]) { int temp = arr[j]; arr[j] = arr[j - 1]; arr[j - 1] = temp; j--; } } } ``` 4. 希尔排序 ``` public static void shellSort(int[] arr) { int len = arr.length; int gap = len / 2; while (gap > 0) { for (int i = gap; i < len; i++) { int j = i; while (j - gap >= 0 && arr[j] < arr[j - gap]) { int temp = arr[j]; arr[j] = arr[j - gap]; arr[j - gap] = temp; j -= gap; } } gap /= 2; } } ``` 5. 归并排序 ``` public static void mergeSort(int[] arr, int left, int right) { if (left < right) { int mid = (left + right) / 2; mergeSort(arr, left, mid); mergeSort(arr, mid + 1, right); merge(arr, left, mid, right); } } public static void merge(int[] arr, int left, int mid, int right) { int[] temp = new int[right - left + 1]; int i = left; int j = mid + 1; int k = 0; while (i <= mid && j <= right) { if (arr[i] <= arr[j]) { temp[k++] = arr[i++]; } else { temp[k++] = arr[j++]; } } while (i <= mid) { temp[k++] = arr[i++]; } while (j <= right) { temp[k++] = arr[j++]; } for (int p = 0; p < temp.length; p++) { arr[left + p] = temp[p]; } } ``` 6. 快速排序 ``` public static void quickSort(int[] arr, int left, int right) { if (left < right) { int pivotIndex = partition(arr, left, right); quickSort(arr, left, pivotIndex - 1); quickSort(arr, pivotIndex + 1, right); } } public static int partition(int[] arr, int left, int right) { int pivot = arr[right]; int i = left; for (int j = left; j < right; j++) { if (arr[j] < pivot) { int temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; i++; } } int temp = arr[i]; arr[i] = arr[right]; arr[right] = temp; return i; } ``` 7. 堆排序 ``` public static void heapSort(int[] arr) { for (int i = arr.length / 2 - 1; i >= 0; i--) { adjustHeap(arr, i, arr.length); } for (int i = arr.length - 1; i > 0; i--) { int temp = arr[0]; arr[0] = arr[i]; arr[i] = temp; adjustHeap(arr, 0, i); } } public static void adjustHeap(int[] arr, int i, int len) { int temp = arr[i]; for (int k = i * 2 + 1; k < len; k = k * 2 + 1) { if (k + 1 < len && arr[k] < arr[k + 1]) { k++; } if (arr[k] > temp) { arr[i] = arr[k]; i = k; } else { break; } } arr[i] = temp; } ```

用java语言比较所有的内部排序算法

以下是Java语言实现所有内部排序算法的示例代码: ```java import java.util.Arrays; import java.util.Random; public class SortComparison { public static void main(String[] args) { int[] arr1 = generateRandomArray(10000); // 生成随机数组 int[] arr2 = arr1.clone(); // 复制数组 int[] arr3 = arr1.clone(); int[] arr4 = arr1.clone(); int[] arr5 = arr1.clone(); int[] arr6 = arr1.clone(); int[] arr7 = arr1.clone(); int[] arr8 = arr1.clone(); int[] arr9 = arr1.clone(); int[] arr10 = arr1.clone(); long startTime, endTime; startTime = System.currentTimeMillis(); // 记录开始时间 Arrays.sort(arr1); // 使用Arrays.sort()内置排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("Arrays.sort()耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 bubbleSort(arr2); // 使用冒泡排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("冒泡排序耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 selectionSort(arr3); // 使用选择排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("选择排序耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 insertionSort(arr4); // 使用插入排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("插入排序耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 quickSort(arr5, 0, arr5.length - 1); // 使用快速排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("快速排序耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 mergeSort(arr6, 0, arr6.length - 1); // 使用归并排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("归并排序耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 heapSort(arr7); // 使用堆排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("堆排序耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 shellSort(arr8); // 使用希尔排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("希尔排序耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 countingSort(arr9); // 使用计数排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("计数排序耗时: " + (endTime - startTime) + "ms"); startTime = System.currentTimeMillis(); // 记录开始时间 bucketSort(arr10); // 使用桶排序算法 endTime = System.currentTimeMillis(); // 记录结束时间 System.out.println("桶排序耗时: " + (endTime - startTime) + "ms"); } private static int[] generateRandomArray(int n) { int[] arr = new int[n]; Random random = new Random(); for (int i = 0; i < n; i++) { arr[i] = random.nextInt(n); } return arr; } private static void bubbleSort(int[] arr) { for (int i = 0; i < arr.length - 1; i++) { for (int j = i + 1; j < arr.length; j++) { if (arr[i] > arr[j]) { swap(arr, i, j); } } } } private 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; } } swap(arr, i, minIndex); } } private static void insertionSort(int[] arr) { for (int i = 1; i < arr.length; i++) { int temp = arr[i]; int j = i - 1; while (j >= 0 && arr[j] > temp) { arr[j + 1] = arr[j]; j--; } arr[j + 1] = temp; } } private static void quickSort(int[] arr, int left, int right) { if (left < right) { int pivot = partition(arr, left, right); quickSort(arr, left, pivot - 1); quickSort(arr, pivot + 1, right); } } private static int partition(int[] arr, int left, int right) { int pivot = arr[left]; int i = left + 1, j = right; while (i <= j) { if (arr[i] < pivot) { i++; } else if (arr[j] > pivot) { j--; } else { swap(arr, i++, j--); } } swap(arr, left, j); return j; } private static void mergeSort(int[] arr, int left, int right) { if (left < right) { int mid = left + (right - left) / 2; mergeSort(arr, left, mid); mergeSort(arr, mid + 1, right); merge(arr, left, mid, right); } } private static void merge(int[] arr, int left, int mid, int right) { int[] temp = new int[right - left + 1]; int i = left, j = mid + 1, k = 0; while (i <= mid && j <= right) { if (arr[i] <= arr[j]) { temp[k++] = arr[i++]; } else { temp[k++] = arr[j++]; } } while (i <= mid) { temp[k++] = arr[i++]; } while (j <= right) { temp[k++] = arr[j++]; } for (int p = 0; p < temp.length; p++) { arr[left + p] = temp[p]; } } private static void heapSort(int[] arr) { for (int i = arr.length / 2 - 1; i >= 0; i--) { adjustHeap(arr, i, arr.length); } for (int i = arr.length - 1; i >= 0; i--) { swap(arr, 0, i); adjustHeap(arr, 0, i); } } private static void adjustHeap(int[] arr, int i, int len) { int temp = arr[i]; for (int j = 2 * i + 1; j < len; j = 2 * j + 1) { if (j + 1 < len && arr[j] < arr[j + 1]) { j++; } if (arr[j] > temp) { arr[i] = arr[j]; i = j; } else { break; } } arr[i] = temp; } private static void shellSort(int[] arr) { int gap = arr.length / 2; while (gap > 0) { for (int i = gap; i < arr.length; i++) { int temp = arr[i]; int j = i - gap; while (j >= 0 && arr[j] > temp) { arr[j + gap] = arr[j]; j -= gap; } arr[j + gap] = temp; } gap /= 2; } } private static void countingSort(int[] arr) { int max = Arrays.stream(arr).max().getAsInt(); 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; } } } private static void bucketSort(int[] arr) { int max = Arrays.stream(arr).max().getAsInt(); int min = Arrays.stream(arr).min().getAsInt(); int bucketNum = (max - min) / arr.length + 1; int[][] buckets = new int[bucketNum][arr.length]; int[] bucketIndex = new int[bucketNum]; for (int i = 0; i < arr.length; i++) { int bucketPos = (arr[i] - min) / arr.length; buckets[bucketPos][bucketIndex[bucketPos]++] = arr[i]; } int index = 0; for (int i = 0; i < bucketNum; i++) { insertionSort(buckets[i]); for (int j = 0; j < bucketIndex[i]; j++) { arr[index++] = buckets[i][j]; } } } private static void swap(int[] arr, int i, int j) { int temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } } ``` 该示例中,使用了Java实现的所有内部排序算法,分别为:Arrays.sort()、冒泡排序、选择排序、插入排序、快速排序、归并排序、堆排序、希尔排序、计数排序和桶排序。generateRandomArray()方法用于生成随机数组,swap()方法用于交换数组中两个元素的位置,其他方法均为各种排序算法的实现。在main()方法中,分别对每个排序算法进行测试,并输出排序时间。

相关推荐

最新推荐

recommend-type

node-v7.2.0-linux-arm64.tar.xz

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

node-v6.14.2-sunos-x64.tar.xz

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

rbac权限控制框架:1.支持角色继承,数据组,行为组.zip

rbac权限控制框架:1.支持角色继承,数据组,行为组.zip abac,rbac权限控制框架 支持角色继承,数据组,行为组 支持动态角色和静态角色 usage 用户与角色需要额外维护 权限控制规则默认驻留内存, 可自定义RuleRepository实现 角色继承关系默认驻留内存, 可自定义RoleHierarchyRepository实现 数据组关系默认驻留内存, 可自定义DataGroupRepository实现 行为组关系默认驻留内存, 可自定义ActionGroupRepository实现 若使用动态角色需要实现DynamicRoleDefiner
recommend-type

utlog.sqlite

utlog.sqlite
recommend-type

node-v0.12.8-x64.msi

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

如何用python编写api接口

在Python中编写API接口可以使用多种框架,其中比较流行的有Flask和Django。这里以Flask框架为例,简单介绍如何编写API接口。 1. 安装Flask框架 使用pip命令安装Flask框架: ``` pip install flask ``` 2. 编写API接口 创建一个Python文件,例如app.py,编写以下代码: ```python from flask import Flask, jsonify app = Flask(__name__) @app.route('/api/hello', methods=['GET']) def hello():
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。