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

怎样在微信上做网站优惠券精选网站怎么做

怎样在微信上做网站,优惠券精选网站怎么做,国家企业信用信息查询官网,wordpress空间租赁目录 1.Hoare单趟排序思想 2.单趟排序代码 初次写的代码 运行结果 查找问题原因 尝试解决问题 初次修正后代码 运行结果 正确的单趟排序代码 3.将单趟排序嵌入 如何递归? 递归结束的条件 1.较容易分析的结束条件:leftright 2.以{2,1}为例分析另一个结束条件 完整…

目录

1.Hoare单趟排序思想

2.单趟排序代码

初次写的代码

 运行结果

查找问题原因

尝试解决问题

初次修正后代码

运行结果

正确的单趟排序代码

3.将单趟排序嵌入

如何递归?

递归结束的条件

1.较容易分析的结束条件:left==right

2.以{2,1}为例分析另一个结束条件

完整代码

运行结果


1.Hoare单趟排序思想

例如对于无序数组arr={6,1,2,7,9,3,4,5,10,8},排升序

① 选一个基准值(又叫关键值)key,一般来说key选arr[0](其实key也可以取其他值,下篇会详细介绍)

② 如果数组一共n个数,两个指针left和right分别从数组的左侧arr[0]和右侧arr[n-1]出发,其中right先走

③ left找到arr[left]比key小的就停止right需要找到arr[right]比key大的,之后arr[left]和arr[right]交换,left和right继续寻找,直到left>right或left==right退出

④ 最后将arr[key_i]和arr[left]交换,完成一次单趟排序

{6,1,2,7,9,3,4,5,10,8} --> {3,1,2,5,4,6,9,7,10,8}(比6小的都在6的左边.比6大的都在6的右边)

2.单趟排序代码

初次写的代码

//单趟快速排序
int key_i = left;
while (left < right)
{//由于key_i==left,因此right指针先走//右边找小while (arr[right] > arr[key_i]){right--;}//左边找大while (arr[left] < arr[key_i]){left++;}Swap(&arr[left], &arr[right]);
}Swap(&arr[key_i], &arr[left]);

 运行结果

实际上运行结果不正确,6左侧有9,9比6大

查找问题原因

可以在while (arr[right] > arr[key_i])处下断点调试

发现问题:left==0不符合要求

尝试解决问题

可在循环前让left==1跳过arr[0]

	int key_i = left;left++;while (left < right){//......}

执行结果:实际上运行结果不正确,6左侧有9,9比6大

尝试寻找原因

下断点调试,

上图说明:到目前为止都没有什么问题

执行到下图时,问题出现:left>right还没有退出!

因此要在两个内循环中都加入条件: left<right,确保不越界!

初次修正后代码
//单趟快速排序
int key_i = left;
left++;
while (left < right)
{//由于key_i==left,因此right指针先走//右边找小while (left < right && arr[right] > arr[key_i]){right--;}//左边找大while (left < right && arr[left] < arr[key_i]){left++;}Swap(&arr[left], &arr[right]);
}Swap(&arr[key_i], &arr[left]);
运行结果

没有问题了,与设想的结果相同


其实修正后的代码还有巨大的问题!!

对{1,2,3,4,5}排序,执行结果反而将升序数组的顺序打乱了,问题在哪里?

执行到Swap(&arr[key_i], &arr[left]);时,key_i==0,left==1,导致错误互换,应该将left++删除

执行结果:没有问题了,与设想的结果相同


其实修正后的代码还有巨大的问题!!

对这个数组排序{6,1,2,7,9,3,4,5,10,6}会死循环

arr[right] == arr[key_i] 和 arr[left] == arr[key_i]时right没有变化,导致一直在while (left<right)里执行无法退出

改成while (left < right && arr[right] >= arr[key_i])和while (left < right && arr[left] <= arr[key_i])即可让left和right指针继续查找,而且避免了在while (left<right)执行前让left++的情况


正确的单趟排序代码

	//单趟快速排序int key_i = left;while (left < right){//由于key_i==left,因此right指针先走//右边找小while (left < right && arr[right] >= arr[key_i]){right--;}//左边找大while (left < right && arr[left] <= arr[key_i]){left++;}Swap(&arr[left], &arr[right]);}Swap(&arr[key_i], &arr[left]);

3.将单趟排序嵌入

如何递归?

第一次单趟排序后的数组{3,1,2,5,4,6,9,7,10,8},接下来分别对6的左侧数据和右侧数据排序

左侧数据表示的区间为[begin,key_i-1] ,右侧数据表示的区间为[key_i+1,end],直接递归调用即可

	int begin = left;int end = right;//循环省略QuickSort(arr, begin, key_i - 1);QuickSort(arr, key_i + 1,end);

考虑到循环执行时,left和right的值会改变,因此需要先保存left和right的值至begin和end中

画图为(极像二叉树的递归)

递归结束的条件

何时从递推到回归?(注意返回的条件写在QuickSort函数的最前面)

1.较容易分析的结束条件:left==right

2.以{2,1}为例分析另一个结束条件

 

则另一个结束条件为left>right

综上:递推结束的条件为left>=right

(其实从区间也能看出递推结束的条件:左区间 [begin,key_i-1]推出当begin<key_i-1时区间成立,begin对应形参left,key_i-1对应形参right,因此left<right;右区间 [key_i+1,end]推出当key_i+1<end时区间成立,key_i+1对应形参left,end对应形参right,因此left<right)

**注意:递归函数先写递归的结束条件再写递推的具体内容**

完整代码

void QuickSort(int* arr, int left, int right)
{if (left >= right)return;//单趟快速排序int begin = left;int end = right;int key_i = left;while (left < right){//由于key_i==left,因此right指针先走//右边找小while (left < right && arr[right] >= arr[key_i]){right--;}//左边找大while (left < right && arr[left] <= arr[key_i]){left++;}Swap(&arr[left], &arr[right]);}Swap(&arr[key_i], &arr[left]);key_i = left;//arr[key_i]和arr[left]交换后下标要改变,否则会对下次递归产生不利结果QuickSort(arr, begin, key_i - 1);QuickSort(arr, key_i + 1,end);
}

运行结果


注:有关Hoare排序为什么key_i==left要让right先走的原因和Hoare排序的优化见下篇文章

http://www.yayakq.cn/news/27203/

相关文章:

  • 网站建设培训公司排名哪个网站做ic外单好
  • 手机搭建网站教程视频教程自己做的视频网站视频加载慢
  • 网站gif小图标网站建设中服务器搭建方式
  • 乐都企业网站建设多少钱网站建设需要收集资料吗
  • pc网站制作公司wordpress什么主题好
  • 网站建立明细预计表网络架构配置
  • 网站建设与管理总结网站开发前期准备
  • 义乌企业网站设计如何用vs2010做网站
  • 石家庄做网站汉狮网络建设网站是否需要一个主机
  • 网站设计风格升级高大上网站设计
  • 用腾讯云服务器做网站h5做网站
  • 相关网站查询把网站做成手机版
  • 那个网站可教做课件好开发平台搭建
  • 做app 的模板下载网站有哪些内容如何免费找精准客户
  • 网站建设的布局对网络推广的影响页游游戏
  • 建设网站的公司济南兴田德润o评价招商网站建设需要什么
  • 江门网站推广技巧方法WordPress浩子
  • 购物网站域名大小大神部落 网站建设
  • 站长之家新网址营销型网站一个多少钱
  • 长宁区小学网站建设外包加工网官网下载app
  • 移动网站建设厂家在网站上做漂浮
  • 潍坊高端网站建设价格如何批量建站
  • 网站空间怎么选择萧山网站建设那家好
  • 浙江广厦建设职业技术学院招生网站合同备案号查询系统
  • 微信网站需要域名吗网站网络投票建设步骤
  • 慈溪做网站公司哪家好色盲怎么治疗
  • 苏州归巢网络科技有限公司站长工具seo综合查询怎么关闭
  • 怎么做淘宝推广网站学做网站哪里学
  • 网站找不到的原因wordpress怎么分页
  • 建设网站好处自己建设网站麻烦吗