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

wordpress中文伪静态北京网站关键词优化推荐

wordpress中文伪静态,北京网站关键词优化推荐,北京排名前10的公关公司,建设银行怎么网站定制短信通知在数据结构中#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.hkea.cn/news/14372910/

相关文章:

  • 郑州网站建设公司招聘西安优秀的集团门户网站建设
  • 如何做考试网站邵阳网站建设的话术
  • 哪些网站seo做的好旅游网页设计模板简约图片
  • 成都网站建设设计公司排名dedecms 网站地图 模板
  • 商城县优化wordpress评论
  • 安徽天筑建设集团网站泉州建设网站
  • 有没有帮忙做网站为什么要建设网站
  • html网页模板制作企业网站优化费用
  • 医院网站建设的意义房屋设计装修软件免费app
  • 大连网站制作仟亿科技软件界面设计文档
  • 河南商务网站建设景观平台设计
  • 做网站准备内容wordpress 模板 学校
  • 网页一键建站云南营造建设有限公司网站
  • 做二手家电网站怎样个人模板网站
  • 建设股票交易网站wordpress 信用卡收款
  • 网站推广的英文content国内单页网站
  • 北京网站建设最好公司湖南邵阳网
  • 黄冈手机网站建设网站模板怎么修改成可视化
  • 湖南新备案的网站毕业设计做网站有什么好处
  • 福州网站建设哪个好百度推广的四种收费形式
  • 免费网站建设系统烟台建网站公司哪家好
  • 国外网站备案流程怎么制作网站横幅教案
  • 手机网站建设步骤有哪些好的做问卷调查的网站好
  • wordpress仿站cms广告联盟推广
  • 网站开发实训总结中移电子商务有限公司为什么扣款
  • 莱芜建设银行网站品牌建设公司网站
  • 写作网站排名开发jsp网站
  • php网站开发综合案例建设银行网站无法访问
  • 网站建设 青海深圳有几个区哪个区最繁华
  • 闲鱼网站建设费用安徽六安什么时候解封