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

建设外贸网站案例网站建设平台选用分析

建设外贸网站案例,网站建设平台选用分析,影视网站怎么做优化,非标准零加工在数据结构中#xff0c;排序是一个重要的操作#xff0c;它有助于提高数据的可读性和可操作性。排序算法有多种#xff0c;各有优缺点#xff0c;适用于不同的场景。以下是八大经典排序算法的介绍#xff1a; 1. 冒泡排序#xff08;Bubble Sort#xff09; 原理排序是一个重要的操作它有助于提高数据的可读性和可操作性。排序算法有多种各有优缺点适用于不同的场景。以下是八大经典排序算法的介绍 1. 冒泡排序Bubble Sort 原理通过重复遍历要排序的数组每次比较相邻的两个元素如果它们的顺序错误就交换它们的位置。这样最大的元素会逐步“冒泡”到数组的末尾。 时间复杂度O(n^2) 代码示例 void bubbleSort(std::vectorint arr) {int n arr.size();for (int i 0; i n - 1; i) {for (int j 0; j n - i - 1; j) {if (arr[j] arr[j 1]) {std::swap(arr[j], arr[j 1]);}}} }2. 选择排序Selection Sort 原理每次从未排序部分选择最小的元素放到已排序部分的末尾。 时间复杂度O(n^2) 代码示例 void selectionSort(std::vectorint arr) {int n arr.size();for (int i 0; i n - 1; i) {int minIndex i;for (int j i 1; j n; j) {if (arr[j] arr[minIndex]) {minIndex j;}}std::swap(arr[i], arr[minIndex]);} }3. 插入排序Insertion Sort 原理构建有序序列对于未排序数据在已排序序列中从后向前扫描找到相应位置并插入。 时间复杂度O(n^2) 代码示例 void insertionSort(std::vectorint arr) {int n arr.size();for (int i 1; i n; 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;} }4. 希尔排序Shell Sort 原理是插入排序的一种改进通过将数组分割成若干子序列分别进行插入排序从而加快排序速度。 时间复杂度O(n log n) ~ O(n^2) 代码示例 void shellSort(std::vectorint arr) {int n arr.size();for (int gap n / 2; gap 0; gap / 2) {for (int i gap; i n; i) {int temp arr[i];int j;for (j i; j gap arr[j - gap] temp; j - gap) {arr[j] arr[j - gap];}arr[j] temp;}} }5. 归并排序Merge Sort 原理采用分治法将数组分成两部分分别排序然后合并排序结果。 时间复杂度O(n log n) 代码示例 void merge(std::vectorint arr, int l, int m, int r) {int n1 m - l 1;int n2 r - m;std::vectorint L(n1), R(n2);for (int i 0; i n1; i) {L[i] arr[l i];}for (int j 0; j n2; j) {R[j] arr[m 1 j];}int i 0, j 0, k l;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(std::vectorint arr, int l, int r) {if (l r) {int m l (r - l) / 2;mergeSort(arr, l, m);mergeSort(arr, m 1, r);merge(arr, l, m, r);} }6. 快速排序Quick Sort 原理选择一个基准元素通过一趟排序将待排序数组分成两部分其中一部分比基准元素小另一部分比基准元素大然后递归地对这两部分分别进行快速排序。 时间复杂度平均O(n log n)最坏O(n^2) 代码示例 int partition(std::vectorint arr, int low, int high) {int pivot arr[high];int i (low - 1);for (int j low; j high - 1; j) {if (arr[j] pivot) {std::swap(arr[i], arr[j]);}}std::swap(arr[i 1], arr[high]);return (i 1); }void quickSort(std::vectorint arr, int low, int high) {if (low high) {int pi partition(arr, low, high);quickSort(arr, low, pi - 1);quickSort(arr, pi 1, high);} }7. 堆排序Heap Sort 原理利用堆这种数据结构来排序。最大堆用于升序排序最小堆用于降序排序。 时间复杂度O(n log n) 代码示例 void heapify(std::vectorint arr, int n, int i) {int largest i;int left 2 * i 1;int right 2 * i 2;if (left n arr[left] arr[largest]) {largest left;}if (right n arr[right] arr[largest]) {largest right;}if (largest ! i) {std::swap(arr[i], arr[largest]);heapify(arr, n, largest);} }void heapSort(std::vectorint arr) {int n arr.size();for (int i n / 2 - 1; i 0; --i) {heapify(arr, n, i);}for (int i n - 1; i 0; --i) {std::swap(arr[0], arr[i]);heapify(arr, i, 0);} }8. 计数排序Counting Sort 原理适用于元素范围较小的数组利用数组下标进行排序。 时间复杂度O(n k)其中k是最大值和最小值的范围 代码示例 void countingSort(std::vectorint arr) {int max *std::max_element(arr.begin(), arr.end());int min *std::min_element(arr.begin(), arr.end());int range max - min 1;std::vectorint count(range), output(arr.size());for (int i 0; i arr.size(); i) {count[arr[i] - min];}for (int i 1; i count.size(); i) {count[i] count[i - 1];}for (int i arr.size() - 1; i 0; --i) {output[count[arr[i] - min] - 1] arr[i];count[arr[i] - min]--;}for (int i 0; i arr.size(); i) {arr[i] output[i];} }总结 这些排序算法各有优劣选择合适的排序算法需要根据数据规模和具体场景来决定。一般来说快速排序和归并排序适用于大多数情况而像计数排序则适用于特定条件下的排序。
http://www.w-s-a.com/news/432987/

相关文章:

  • php和网站开发网络软营销
  • 大型做网站的公司有哪些wordpress注册链接无效
  • 推荐门户网站建设公司网站开发移动端
  • 公司网站的栏目设置成都十大监理公司排名
  • 安溪住房和城乡建设网站关岭县建设局网站
  • 网站域名注销备案徐州房产网
  • 筑聘网windows优化大师自动安装
  • 龙华高端网站设计门户网站建设方案公司
  • 网站开发作用网站建设哪家专业
  • 网站设计报告总结南宁商城网站推广公司
  • 淘宝做店招的网站免费网站建设自助建站
  • 重庆工信部网站绵阳公司网站建设
  • 购物网站开发流程制作企业网页
  • 定州哪里可以做网站建设项目环境影响登记表备案系统网站
  • 网站建设费属于广告费小猪网站怎么做的
  • 国内优秀设计网站站长哈尔滨微网站建设
  • 如何建设一个优秀的电商网站沐风seo
  • 从零开始学网站建设知乎安防网站下载
  • 打开网站弹出qq应用软件有哪些
  • 温州网站建设seo网站 如何做 中英文切换
  • 聊城做网站的公司资讯信阳 网站建设
  • 天津市工程建设交易网站查汗国珠海 网页设计
  • 龙果学院大型网站稳定性建设汾阳做网站
  • 湖北 个人网站备案时间域名查询备案查询
  • 网站推广方式校园网站怎么建
  • 长沙seo网站排名怎么在百度发帖
  • 织梦贷款网站模板做印章网站
  • 彭州做网站上海百度网络推广
  • 广州网站搭建快速提升网站排名荧光字网站
  • 15年做那些网站能致富做seo是什么意思