14、二次时间内列出所有排序反转

二次时间内列出所有排序反转

1. 背景与问题提出

在处理排序反转问题时,当存在不良组件时,寻找排序反转集的现有算法复杂度较高。虽然有 $O(n^3)$ 的算法来寻找排序反转集,但平均情况下复杂度为 $O(n^2)$ ,且能在线性时间内检测不良组件的存在。我们关注的是对不对应于不良组件的 FCIs 进行排序的瓶颈,即会创建不良组件的循环分裂反转(非排序反转)。

相关定义

  • 不良反转 :创建不良组件的反转。
  • 不安全反转 :不良的循环分裂反转。

例如,在某个排列中,反转 $\rho(6,8)$ 可能就是不安全的。

传统算法会逐个检查潜在的 $\Omega(n^2)$ 个循环分裂反转是否安全,而我们采用相反的方法,即预测哪些反转可能不安全并避免列出它们。具体做法是,先刻画排列中的不祥子串,即那些通过一次反转可能变成不良组件的子串。

2. 不祥子串

2.1 单组件排列的不祥子串

一个排列的子串是不祥子串,当且仅当存在元素 $e$ 和 $f$ ,使得该子串符合以下模板(或其反转):
1. $(eAX -f -B)$:其中 $A$、$-B$ 和 $X$ 是排列的子串,$A$ 仅含正元素,$-B$ 仅含负元素。
2. $(-A -eXBf)$:其中 $-A$、$B$ 和 $X$ 是排列的子串,$-A$ 仅含负元素,$B$ 仅含正元素,且 $e$ 为负。
3. $(eA -BC f)$:其中 $A$、$-B$ 和 $C$ 是排列的子串

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值