• 1829. 每个查询的最大异或值


    1829. 每个查询的最大异或值

    给你一个 有序 数组 nums ,它由 n 个非负整数组成,同时给你一个整数 maximumBit 。你需要执行以下查询 n 次:

    找到一个非负整数 k < 2maximumBit ,使得 nums[0] XOR nums[1] XOR ... XOR nums[nums.length-1] XOR k 的结果 最大化 。k 是第 i 个查询的答案。
    从当前数组 nums 删除 最后 一个元素。
    
    • 1
    • 2

    请你返回一个数组 answer ,其中 answer[i]是第 i 个查询的结果。

    示例 1:

    输入:nums = [0,1,1,3], maximumBit = 2
    输出:[0,3,2,3]
    解释:查询的答案如下:
    第一个查询:nums = [0,1,1,3],k = 0,因为 0 XOR 1 XOR 1 XOR 3 XOR 0 = 3 。
    第二个查询:nums = [0,1,1],k = 3,因为 0 XOR 1 XOR 1 XOR 3 = 3 。
    第三个查询:nums = [0,1],k = 2,因为 0 XOR 1 XOR 2 = 3 。
    第四个查询:nums = [0],k = 3,因为 0 XOR 3 = 3 。

    示例 2:

    输入:nums = [2,3,4,7], maximumBit = 3
    输出:[5,2,6,5]
    解释:查询的答案如下:
    第一个查询:nums = [2,3,4,7],k = 5,因为 2 XOR 3 XOR 4 XOR 7 XOR 5 = 7。
    第二个查询:nums = [2,3,4],k = 2,因为 2 XOR 3 XOR 4 XOR 2 = 7 。
    第三个查询:nums = [2,3],k = 6,因为 2 XOR 3 XOR 6 = 7 。
    第四个查询:nums = [2],k = 5,因为 2 XOR 5 = 7 。

    示例 3:

    输入:nums = [0,1,2,2,5,7], maximumBit = 3
    输出:[4,3,6,4,6,7]

    这题感觉没什么特点,正常去做就可以啦,解题代码如下:

    /**
     * Note: The returned array must be malloced, assume caller calls free().
     */
    int* getMaximumXor(int* nums, int numsSize, int maximumBit, int* returnSize){
        int ar[26];
        int sizemax=0;
        int *re=(int *)malloc(sizeof(int)*numsSize);
        for(int i=0;i<26;i++){
            ar[i]=0;
        }
        for(int i=0;i<numsSize;i++){
           int n=nums[i];
           int size=0;
           while(n){
               ar[size++]=ar[size]+n%2;
               n=n/2;
    
           }
           sizemax=fmax(sizemax,size);
        }
       
      
        int p=0;
    
        
       
    
         for(int i=numsSize;i>0;i--){
             int t=0;
             int e=1;
    
    
             if(i==numsSize){
                 for(int j=0;j<maximumBit;j++){
                     if(ar[j]%2==0){
                         t=t+e;
                     }
                     e=e*2;
    
                 }
           }
           else{
          int n=nums[i];
           int size=0;
           while(n){
               ar[size++]=ar[size]-n%2;
               n=n/2;
    
           }
        
            for(int i=0;i<sizemax;i++){
         
        }
            for(int j=0;j<maximumBit;j++){
               
                     if(ar[j]%2==0){
                       
                         t=t+e;
                         
                     }
                     e=e*2;
    
                 }
    
           }
        
           re[p++]=t;
    
              
        }
    
    
        *returnSize=numsSize;
        return re;
    
    }
    
    • 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
  • 相关阅读:
    postgresql数组重叠(有共同元素)查询
    鸿蒙登录页面及页面跳转的设计
    Python tkinter-- 第16章 菜单(Menu)属性
    Elasticsearch核心概念解析:索引、文档与类型
    谷歌浏览器占CPU非常高的解决办法
    企业级信息化系统 ERP、OA、CRM、EAM、WMS、MES、PM
    redis未授权与权限获取
    keil5debug无法进行调试
    技术分享 | 云原生多模型 NoSQL 概述
    A_A07_001 TFT彩图提取软件使用
  • 原文地址:https://blog.csdn.net/weixin_43327597/article/details/128172859