田忌赛马
将⻬王和⽥忌的⻢按照战⽃⼒排序,然后按照排名⼀⼀对⽐。如果⽥忌的⻢能赢,那就⽐赛,如果赢不了, 那就换个垫底的来送⼈头,保存实⼒。
int n = nums1.length; sort(nums1); // ⽥忌的⻢ sort(nums2); // ⻬王的⻢ // 从最快的⻢开始⽐ for (int i = n - 1; i >= 0; i--) { if (nums1[i] > nums2[i]) { // ⽐得过,跟他⽐ } else { // ⽐不过,换个垫底的来送⼈头 } }
实例,力扣870题:

func advantageCount(nums1 []int, nums2 []int) []int {
sort.Ints(nums1)
p:=make([]pair,len(nums2))
for i:=0;i<len(nums2);i++{
p[i].index=i
p[i].value=nums2[i]
}
sort.Sort(pairs(p))
i,j:=len(nums1)-1,len(nums1)-1
res:=make([]int,len(nums1))
count:=0
for j>-1{
if nums1[i]>p[j].value{
res[p[j].index]=nums1[i]
i--
}else{
res[p[j].index]=nums1[count]
count++
}
j--
}
return res
}
type pair struct{
index int
value int
}
type pairs []pair
func (t pairs) Len() int {
return len(t)
}
func (t pairs) Swap(i, j int){
t[i], t[j] = t[j], t[i]
}
func (t pairs) Less(i, j int) bool {
return t[j].value > t[i].value
}

浙公网安备 33010602011771号