田忌赛马

将⻬王和⽥忌的⻢按照战⽃⼒排序,然后按照排名⼀⼀对⽐。如果⽥忌的⻢能赢,那就⽐赛,如果赢不了, 那就换个垫底的来送⼈头,保存实⼒。

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 
}

  

 

posted @ 2022-03-17 20:01  ☞@_@  阅读(39)  评论(0编辑  收藏  举报