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

北京企业网站建设价格北京快速优化排名

北京企业网站建设价格,北京快速优化排名,wordpress教程 数据库,建站公司还行吗在 C 语言中,可以通过嵌套循环和比较运算符来实现常见的排序算法,比如冒泡排序、选择排序或插入排序 目录 基础算法: 1.冒泡排序(Bubble Sort) 2.选择排序(Selection Sort) 3.插入排序&…

在 C 语言中,可以通过嵌套循环和比较运算符来实现常见的排序算法,比如冒泡排序选择排序插入排序

目录

基础算法:

1.冒泡排序(Bubble Sort)

2.选择排序(Selection Sort)

3.插入排序(Insertion Sort)

高级算法:

1. 快速排序(Quick Sort)

2. 归并排序(Merge Sort)

3. 堆排序(Heap Sort)


基础算法(简单易实现):冒泡排序、选择排序、插入排序

高级算法(性能更优):快速排序、归并排序、堆排序

基础算法:

1. 冒泡排序(Bubble Sort)

冒泡排序是简单直观的排序方法,通过多次比较相邻元素交换位置来排序。

#include <stdio.h>void bubbleSort(int arr[], int size) {for (int i = 0; i < size - 1; i++) {for (int j = 0; j < size - i - 1; j++) {if (arr[j] > arr[j + 1]) { // 如果当前元素大于后一个元素,则交换int temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}}
}int main() {int arr[] = {5, 2, 8, 3, 7};int size = sizeof(arr) / sizeof(arr[0]);printf("排序前: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");bubbleSort(arr, size);printf("排序后: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

备注说明:这里在内循环,j<size-i-1的目的是:因为每进行一次外层循环,数组末尾的一个最大元素会被排序好,因此后续的内层循环会减少比较的次数。

2.选择排序(Selection Sort)

选择排序通过在未排序部分找到最小(最大)元素,然后将其与未排序部分的第一个元素交换位置。

#include <stdio.h>void selectionSort(int arr[], int size) {for (int i = 0; i < size - 1; i++) {int minIndex = i; // 假设当前元素是最小值for (int j = i + 1; j < size; j++) {if (arr[j] < arr[minIndex]) {minIndex = j; // 找到更小的元素}}// 交换最小值和当前位置int temp = arr[i];arr[i] = arr[minIndex];arr[minIndex] = temp;}
}int main() {int arr[] = {5, 2, 8, 3, 7};int size = sizeof(arr) / sizeof(arr[0]);printf("排序前: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");selectionSort(arr, size);printf("排序后: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

备注说明:

3.插入排序(Insertion Sort)

插入排序通过逐步将未排序部分的元素插入到已排序部分的正确位置来排序

#include <stdio.h>void insertionSort(int arr[], int size) {for (int i = 1; i < size; 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;}
}int main() {int arr[] = {5, 2, 8, 3, 7};int size = sizeof(arr) / sizeof(arr[0]);printf("排序前: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");insertionSort(arr, size);printf("排序后: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

高级算法:

1. 快速排序(Quick Sort)

快速排序是一种分治算法,通过选定一个“基准”(pivot),将数组分为两部分,递归排序子数组。

#include <stdio.h>void quickSort(int arr[], int low, int high) {if (low < high) {int pivot = arr[low]; // 基准int i = low, j = high;while (i < j) {while (i < j && arr[j] >= pivot) j--; // 从右向左找小于基准的if (i < j) arr[i++] = arr[j];        // 放到左边while (i < j && arr[i] <= pivot) i++; // 从左向右找大于基准的if (i < j) arr[j--] = arr[i];        // 放到右边}arr[i] = pivot; // 基准放在最终位置quickSort(arr, low, i - 1); // 排序左边部分quickSort(arr, i + 1, high); // 排序右边部分}
}int main() {int arr[] = {5, 2, 8, 3, 7};int size = sizeof(arr) / sizeof(arr[0]);printf("排序前: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");quickSort(arr, 0, size - 1);printf("排序后: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

2. 归并排序(Merge Sort)

归并排序也是一种分治算法,分为两部分分别排序,再合并为有序数组。

#include <stdio.h>void merge(int arr[], int left, int mid, int right) {int n1 = mid - left + 1;int n2 = right - mid;int L[n1], R[n2];// 将数据复制到临时数组for (int i = 0; i < n1; i++) L[i] = arr[left + i];for (int i = 0; i < n2; i++) R[i] = arr[mid + 1 + i];int i = 0, j = 0, k = left;while (i < n1 && j < n2) {if (L[i] <= R[j]) {arr[k++] = L[i++];} else {arr[k++] = R[j++];}}while (i < n1) arr[k++] = L[i++];while (j < n2) arr[k++] = R[j++];
}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);}
}int main() {int arr[] = {5, 2, 8, 3, 7};int size = sizeof(arr) / sizeof(arr[0]);printf("排序前: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");mergeSort(arr, 0, size - 1);printf("排序后: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

3. 堆排序(Heap Sort)

堆排序通过构造一个堆(最大堆或最小堆)来实现排序。

#include <stdio.h>void heapify(int arr[], int size, int root) {int largest = root;int left = 2 * root + 1;int right = 2 * root + 2;if (left < size && arr[left] > arr[largest]) largest = left;if (right < size && arr[right] > arr[largest]) largest = right;if (largest != root) {int temp = arr[root];arr[root] = arr[largest];arr[largest] = temp;heapify(arr, size, largest);}
}void heapSort(int arr[], int size) {// 构建最大堆for (int i = size / 2 - 1; i >= 0; i--) {heapify(arr, size, i);}// 逐步将堆顶元素交换到数组末尾,并调整堆for (int i = size - 1; i > 0; i--) {int temp = arr[0];arr[0] = arr[i];arr[i] = temp;heapify(arr, i, 0);}
}int main() {int arr[] = {5, 2, 8, 3, 7};int size = sizeof(arr) / sizeof(arr[0]);printf("排序前: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");heapSort(arr, size);printf("排序后: ");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

http://www.tj-hxxt.cn/news/6326.html

相关文章:

  • html5 企业网站模板国外友链买卖平台
  • 做logo专用的网站是哪个全网营销代运营
  • ps做网站页面先后顺序营销做得好的品牌
  • 上海土地建设官方网站人工智能培训
  • 用HTML和css做购物网站中国腾讯和联通
  • 给网站做导流百度帐号管家
  • 网站右侧广告微信小程序开发平台
  • 漫画网站css模板谷歌浏览器下载视频
  • 网站备案拍照要求百度广告搜索引擎
  • 许昌网站制作公司营销网址
  • .net做的网站公司关键词排名优化
  • 线上做交互的网站搜索关键词排名工具
  • 网站建设wordpress比较企业培训课程视频
  • 网站建设公司运营模式电商是做什么的
  • 襄阳网站建设无锡seo网络推广
  • 用vs做的网站怎么打开优化大师的优化项目有哪7个
  • 筛网怎么做网站百度网首页
  • 电商网站改版如何让百度快速收录新网站
  • 网站推广怎么做与发布百度推广点击一次多少钱
  • 前端容易被裁还是后端seo网站分析
  • 素材下载网站源码培训计划方案
  • app投放推广深圳seo优化推广公司
  • 做家具厂招聘有哪些网站网络策划方案
  • 网站列表设计北京官网seo
  • 池州专业网站建设哪家好外贸seo网站建设
  • 浙江省门户网站网站推广具体内容
  • 绛县做网站免费建一个自己的网站
  • 专门做毕设的网站seo搜索引擎优化技术教程
  • 商业网站域名后缀百度快速查询
  • 企业宣传册设计如何做优化排名