• 1818. 绝对差值和-快速排序加二分查找


    1818. 绝对差值和-快速排序加二分查找

    给你两个正整数数组 nums1 和 nums2 ,数组的长度都是 n 。

    数组 nums1 和 nums2 的 绝对差值和 定义为所有 |nums1[i] - nums2[i]|(0 <= i < n)的 总和(下标从 0 开始)。

    你可以选用 nums1 中的 任意一个 元素来替换 nums1 中的 至多 一个元素,以 最小化 绝对差值和。

    在替换数组 nums1 中最多一个元素 之后 ,返回最小绝对差值和。因为答案可能很大,所以需要对 109 + 7 取余 后返回。

    |x| 定义为:

    如果 x >= 0 ,值为 x ,或者
    如果 x <= 0 ,值为 -x
    
    • 1
    • 2

    示例 1:

    输入:nums1 = [1,7,5], nums2 = [2,3,5]
    输出:3
    解释:有两种可能的最优方案:

    • 将第二个元素替换为第一个元素:[1,7,5] => [1,1,5] ,或者
    • 将第二个元素替换为第三个元素:[1,7,5] => [1,5,5]
      两种方案的绝对差值和都是 |1-2| + (|1-3| 或者 |5-3|) + |5-5| = 3

    示例 2:

    输入:nums1 = [2,4,6,8,10], nums2 = [2,4,6,8,10]
    输出:0
    解释:nums1 和 nums2 相等,所以不用替换元素。绝对差值和为 0

    示例 3:

    输入:nums1 = [1,10,4,4,2,7], nums2 = [9,3,5,1,7,4]
    输出:20
    解释:将第一个元素替换为第二个元素:[1,10,4,4,2,7] => [10,10,4,4,2,7]
    绝对差值和为 |10-9| + |10-3| + |4-5| + |4-1| + |2-7| + |7-4| = 20

    这个题目也是非常的棒,建议一定要好好学习一下,解题代码如下:

    
    
    void quick_sort(int *a,int low,int high){
        int l=low,h=high;
        if(low<high){
            int p=a[low];
            while(low<high){
                while(low<high&&a[high]>=p){
                    high--;
    
                }
                a[low]=a[high];
                while(low<high&&a[low]<=p){
                    low++;
                }
                a[high]=a[low];
            }
            a[low]=p;
            quick_sort(a,l,low-1);
            quick_sort(a,low+1,h);
    
        }
    }
    long long  absz(long long  x){
        if(x<0){
            return 0-x;
        }
        return x;
    }
    
    int Bi_search(int *a,int val,int numsSize){
    
        int low=0,high=numsSize-1;
        while(low<high){
            int mid=(low+high)/2;
            if(a[mid]>val){
                high=mid-1;
    
            }
            else if(a[mid]<val){
                low=mid+1;
            }
            else{
                return mid;
            }
    
        }
        if(low==0){
            if(absz(a[low]-val)<absz(a[low+1]-val)){
                return low;
            }
            else{
                return low+1;
            }
    
         
        }
        if(abs(a[low]-val)<abs(a[low-1]-val)){
            return low;
        }
        return low-1;
    
    }
    
    
    int minAbsoluteSumDiff(int* nums1, int nums1Size, int* nums2, int nums2Size){
        int *a=(int *)malloc(sizeof(int)*nums1Size);
        long long abs_sum=0;
        for(int i=0;i<nums1Size;i++){
            a[i]=nums1[i];
            abs_sum=(abs_sum+absz(nums1[i]-nums2[i]));
          
          //  printf("%d ",abs_sum);
    
        }
        long long  max=0;
        long long  t=abs_sum;
        printf("%ld ",abs_sum);
        quick_sort(a,0,nums1Size-1);
        for(int i=0;i<nums1Size;i++){
            long long  index=Bi_search(a,nums2[i],nums1Size);
            
          
            max=fmax(max,absz(nums2[i]-nums1[i])-absz(nums2[i]-a[index]));
            abs_sum=fmin(t-max,abs_sum);
    
          
        }
    return abs_sum%1000000007;
    
    
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
  • 相关阅读:
    mysql 执行计划 type详解
    Java刷题day24
    LeetCode第13题:罗马数字转整数
    WEB3 在 React搭建的Dapp中通过redux全局获取并存储用户ETH与自定义token与交易所存储数量
    PIE-engine 教程 ——影像集合的使用for循环函数(北京市NDVI计算)
    数据结构与算法(C语言版)P4---顺序表、链表总结
    新火种AI|微软扶持下一个OpenAI?Mistral AI新模型对标GPT-4,上线即挤爆
    功能测试:核心原理、挑战以及解决之道
    Springboot系列教程汇总
    【解惑】孜孜不倦,用足球赛程详解c#中的yield return用法
  • 原文地址:https://blog.csdn.net/weixin_43327597/article/details/127127977