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

淘宝客户自己做网站怎么做seo实战密码

淘宝客户自己做网站怎么做,seo实战密码,广州效果图设计公司,温州做网站建设公司创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; 更多算法分析与设计知识专栏&#xff1a;算法分析&#x1f525; 给大家跳…

创作不易,本篇文章如果帮助到了你,还请点赞 关注支持一下♡>𖥦<)!!
主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步!
更多算法分析与设计知识专栏:算法分析🔥
给大家跳段街舞感谢支持!ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ

在这里插入图片描述


目录

  • 一、挖坑填补法
  • 二、区间分割法
  • 三、快排的优化:

快排的基本思想:先确定一个标准值,将比标准值小的元素放在标准值的左侧,比标准值大的元素放在右侧,左右部分分别重复以上的操作,直到整个数组有序。

快速排序是基于分治策略的排序算法

一、挖坑填补法

  1. 选择一个基准元素
  2. 将基准元素挖出,形成一个坑
  3. 从右向左遍历数组,找到第一个比基准元素小的元素,将其填入空坑中,并将此位置视为新的坑
  4. 从左向右遍历数组,找到第一个比基准元素大的元素,将其填入新的空坑中,并将此位置视为新的坑
  5. 重复过程,直到左右指针相遇
  6. 最后将基准元素填入坑中,此时基准元素左边的所有元素都比它小,右边的所有元素都比它大。
  7. 对基准元素左边右边的子数组递归地进行上述操作,直到整个数组有序

image.png

C++代码:

#include <iostream>
#include <cmath>
using namespace std;int partition(int arr[], int left, int right)
{// 确定标准值,保存起来int standard = arr[left];//使用双指针从两端开始,将比标准值大的数放到标准值右侧,小于标准值的放到左侧while (left < right){//从右到左(right到left)找到比标准值小的//如果遇到的值大于等于标准值,则跳过 right--while (left < right && arr[right] >= standard){right--;}//找到了比标准值小的值arr[right],放到左边的left坑中arr[left] = arr[right];//从左到右(left到right)找到比标准值大的//如果遇到的值小于等于标准值,则跳过 left++while (left < right && arr[left] <= standard){left++;}//找到了比标准值大的值arr[left],放到左边的right坑中arr[right] = arr[left];}//中间的坑放入标准值arr[left] = standard;//返回标准值的下标return left;
}void quicksort(int arr[], int left, int right)
{if (arr == NULL || left >= right) return;int standard = partition(arr, left, right);quicksort(arr, left, standard - 1);quicksort(arr, standard + 1, right);
}void print(int arr[], int len)
{if (arr == NULL || len <= 0) return;for (int i = 0; i < len; i++){std::cout << arr[i] << " ";}std::cout << endl;
}int main()
{int arr[] = { 5, 1, 7, 0, 4, 3, 4, 9, 6 };int len = sizeof(arr) / sizeof(arr[0]);cout << "------------------------------" << endl << "原始序列:";print(arr, len);quicksort(arr, 0, len - 1);cout << "------------------------------" << endl << "排序后序列:";print(arr, len);return 0;
}

image.png

二、区间分割法

#include <iostream>
#include <cmath>
using namespace std;int partition(int arr[], int left, int right)
{int nSmall = left - 1;for (left; left < right; left++){if (arr[left] < arr[right]){//小区间扩张if (++nSmall != left){arr[nSmall] = arr[nSmall] ^ arr[left];arr[left] = arr[nSmall] ^ arr[left];arr[nSmall] = arr[nSmall] ^ arr[left];}}}//将标准值放入if (++nSmall != right){arr[nSmall] = arr[nSmall] ^ arr[right];arr[right] = arr[nSmall] ^ arr[right];arr[nSmall] = arr[nSmall] ^ arr[right];}return nSmall;
}
void print(int arr[], int len)
{if (arr == NULL || len <= 0) return;for (int i = 0; i < len; i++){std::cout << arr[i] << " ";}std::cout << endl;
}int main()
{int arr[] = { 5, 1, 7, 0, 4, 3, 4, 9, 6 };int len = sizeof(arr) / sizeof(arr[0]);cout << "------------------------------" << endl << "原始序列:";print(arr, len);quicksort(arr, 0, len - 1);cout << "------------------------------" << endl << "排序后序列:";print(arr, len);return 0;
}

三、快排的优化:

  • 1.标准值的选取:选取三个数字(头、尾、中间),选择大小为中间值
  • 2.分割到数据较少时,不再使用快排,使用插入排序
  • 3.使用栈取代递归
  • 4.尾递归

以下为使用了标准值三选一、按情况使用插入排序的优化后代码:

class Solution {
public:void swap (vector<int>& nums, int i, int j) {     int temp = nums[i];nums[i] = nums[j];nums[j] = temp;} void insertSort (vector<int>& nums, int left, int right) {for (int i = left+1; i <= right; i++) {int temp = nums[i];int j = i-1;for (j = i-1; j >= 0; j--) {if (temp < nums[j]) {nums[j+1] = nums[j];continue;} break;}nums[j+1] = temp;}} int place(vector<int>& nums,int left,int right){//标准值三选一int mid = left + (right-left)/2;if (nums[left] > nums[right]) swap(nums,left,right);if (nums[mid] > nums[right]) swap(nums,mid,right);if (nums[mid] > nums[left]) swap(nums,mid,left); int standard = nums[left];while(left < right){while(left<right&&nums[right]>standard){right--;}nums[left] = nums[right];while(left<right&&nums[left]<standard){left++;}nums[right] = nums[left];}nums[left] = standard;return left;}void quickSort(vector<int>& nums,int left,int right){//分割到数据较少时,不再使用快排,使用插入排序if (right - left <= 5) {insertSort(nums,left,right);return;}     if(nums.size() == 0 || left >= right) return;int standard = place(nums,left,right);quickSort(nums,left,standard-1);quickSort(nums,standard+1,right);}vector<int> sortArray(vector<int>& nums) {quickSort(nums,0,nums.size()-1);return nums;}
};

在这里插入图片描述

大家的点赞、收藏、关注将是我更新的最大动力! 欢迎留言或私信建议或问题。
大家的支持和反馈对我来说意义重大,我会继续不断努力提供有价值的内容!如果本文哪里有错误的地方还请大家多多指出(●'◡'●)
http://www.yidumall.com/news/78300.html

相关文章:

  • 自己做的网站怎么在局域网中访问杭州关键词推广优化方案
  • 哈尔滨建设集团广东企业网站seo哪里好
  • 宣传型企业网站设计方案成都高端网站建设哪家好
  • bootstrap手机网站模板下载百度seo流量
  • 精智wordpress主题百度热搜seo
  • 如何做律师网站百度app客服人工电话
  • 购物网站主页设计图百度开户代理商
  • 做网站能不备案么阿里云建站
  • 网站备案个人和企业的区别西安百度seo代理
  • linux网站建设ui设计公司
  • 百度h5手机版上海百度推广优化排名
  • 泰安三合一网站建设公司优化关键词排名
  • 软件软件开发中山seo关键词
  • 先备案 做网站抖音seo源码搭建
  • 导航网站织梦模板济南做seo外包
  • 网站为什么做重定向牛推网络
  • 一台虚拟主机能建设几个网站免费网页设计制作网站
  • 用eclipse做jsp网站上海百度seo网站优化
  • 北京免费自助建站模板谷歌seo靠谱吗
  • 四川手机网站设计方案seo网络推广什么意思
  • 注册公司需要多少费用济南网站优化排名
  • wordpress提示框美化seo查询官网
  • 哪里做网站seoseo课程
  • 点网站建设百度推广运营专员
  • 网站开发与维护工资多少免费sem工具
  • 做网站的设计文档怎么做如何开发网站
  • 南昌建设人才网站哪里有整站优化
  • 企业网站网站建设电话建网站流程
  • 协会网站设计方案模板百度排名查询
  • 网站定制公司kinglink小红书关键词热度查询