关于分治及其应用,持续更新

I:分治在排序中的应用

d7eb57abfb4f411e96d1728d40566b94.png

这里的排序分为三个步骤:

1:随机取值作为划分的标准,一般选用a[l],a[l+r/2],a[r],设为x。

2:将数组分成>x和<x两部分。

这里采用的方法是取了两个指针i和j,分别让这两个指针向中间走,直到两个指针相遇为止。因为函数中用的do while循环,进入循环后立刻i++或j--,因此在定义时应该让两个指针分别比最小下标少1,比最大下标多1。

3:分别对两部分递归处理。

函数递归,这里要考虑边界问题:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值