首页 > 其他分享 >Find Products of Elements of Big Array

Find Products of Elements of Big Array

时间:2024-05-13 17:22:37浏览次数:33  
标签:Elements big 二进制 Big mid long queries Array sim

Find Products of Elements of Big Array

powerful array for an integer x is the shortest sorted array of powers of two that sum up to x. For example, the powerful array for 11 is [1, 2, 8].

The array big_nums is created by concatenating the powerful arrays for every positive integer i in ascending order: 1, 2, 3, and so forth. Thus, big_nums starts as [121, 241, 42, 41, 2, 48, ...].

You are given a 2D integer matrix queries, where for queries[i] = [fromi, toi, modi] you should calculate (big_nums[fromi] * big_nums[fromi + 1] * ... * big_nums[toi]) % modi.

Return an integer array answer such that answer[i] is the answer to the ith query.

 

Example 1:

Input: queries = [[1,3,7]]

Output: [4]

Explanation:

There is one query.

big_nums[1..3] = [2,1,2]. The product of them is 4. The remainder of 4 under 7 is 4.

Example 2:

Input: queries = [[2,5,3],[7,7,4]]

Output: [2,2]

Explanation:

There are two queries.

First query: big_nums[2..5] = [1,2,4,1]. The product of them is 8. The remainder of 8 under 3 is 2.

Second query: big_nums[7] = 2. The remainder of 2 under 4 is 2.

 

Constraints:

  • 1 <= queries.length <= 500
  • queries[i].length == 3
  • 0 <= queries[i][0] <= queries[i][1] <= 1015
  • 1 <= queries[i][2] <= 105

 

解题思路

  看完了题解感觉也不是那么难,但代码超难写。赛时罚坐了 1 个多小时都没想到正解,感觉最近变笨了好多简单题都不会做。

  为了方便这里规定强数组的下标从 $1$ 开始,且下标为 $0$ 的元素是 $0$。因此每个询问对应的三元组 $(p_0,p_1,p_2)$,应有 $p_0 \gets p_0+1$ 和 $p_1 \gets p_1+1$。

  容易知道强数组中的每个元素表示从数值 $0$ 开始的每个数,在二进制下为 $1$ 的位对应的 $2$ 的幂。因此要求的乘积也是 $2$ 的多少次幂,为此我们只需关注强数组 $[p_0,p_1]$ 内次幂的总和即可。而下标 $x$ 则表示从数值 $0$ 到某个数 $v$ 的某个二进制位内,$1$ 的数量。现在的问题是给定 $x$ 如何快速求出对应的 $v$,即找到最小的一个 $v$,使得 $0 \sim v$ 在二进制下 $1$ 的数量大于等于 $x$。

  显然可以二分出 $v$,那么对于二分出的某个值 $\text{mid}$ 如何快速知道 $0 \sim \text{mid}$ 在二进制下 $1$ 的数量?规定二分的范围是 $\left[0, 10^{15}\right]$,其中 $2^{49} < 10^{15} < 2^{50}$。对此我们可以分别统计 $0 \sim \text{mid}$ 在第 $0$ 位到第 $49$ 位的 $1$ 的数量。打表可以发现规律,对于第 $i$ 位,$2^i$ 个 $0$ 与 $2^i$ 个 $1$ 依次交替出现,因此第 $i$ 位 $1$ 的数量就是 $\left\lfloor \frac{\text{mid}+1}{2^{i+1}} \right\rfloor \times 2^{i} \, + \, \left[ x \bmod 2^{i+1}> 2^{i} \right] \cdot \left( x \bmod 2^{i} \right)$。

  对此我们可以先求出 $p_0$ 对应的 $l$,及 $p_1$ 对应的 $r$。如果 $l = r$,先求出 $0 \sim l-1$ 在二进制下 $1$ 的数量,记为 $c$。暴力枚举 $l$ 的二进制数位,当第 $i$ 位是 $1$ 时,令 $c \gets c + 1$,如果 $p_0 \leq c \leq p_1$ 就累加 $i$。

  如果 $l < r$,先统计 $l$ 在强数组内为 $1$ 的位,具体做法为先求出 $0 \sim l-1$ 在二进制下 $1$ 的数量 $c$,暴力枚举 $l$ 的二进制数位,当第 $i$ 位是 $1$ 时,令 $c \gets c + 1$,如果 $p_0 \leq c$ 就累加 $i$。同理统计 $r$ 在强数组内为 $1$ 的位,具体做法为先求出 $0 \sim r-1$ 在二进制下 $1$ 的数量 $c$,暴力枚举 $r$ 的二进制数位,当第 $i$ 位是 $1$ 时,令 $c \gets c + 1$,如果 $c \leq p_1$ 就累加 $i$。最后统计 $[l+1,r-1]$ 为 $1$ 的位的和,可以用前缀和的思想,分别求 $0 \sim r$ 和 $0 \sim l-1$ 为 $1$ 的位的和,然后做减法。只需在求二进制下第 $i$ 位为 $1$ 的数量的基础上乘上 $i$ 即可。

  在累加了次幂后,只需用快速幂计算 $2$ 的多少次幂即可。

  AC 代码如下,时间复杂度为 $O(q \log^2{R})$,其中 $R = 10^{15}$:

class Solution {
public:
    vector<int> findProductsOfElements(vector<vector<long long>>& queries) {
        vector<int> ans;
        for (auto &p : queries) {
            p[0]++, p[1]++;
            function<long long(long long)> get = [&](long long x) {
                x++;
                long long s = 0;
                for (int i = 0; i <= 49; i++) {
                    s += x / (1ll << i + 1) * (1ll << i);
                    if (x % (1ll << i + 1) > 1ll << i) s += x % (1ll << i);
                }
                return s;
            };
            function<long long(long long)> find = [&](long long x) {
                long long l = 0, r = 1e15;
                while (l < r) {
                    long long mid = l + r >> 1;
                    if (get(mid) >= x) r = mid;
                    else l = mid + 1;
                }
                return l;
            };
            function<int(int, long long, int)> qmi = [&](int a, long long k, int p) {
                int ret = 1 % p;
                while (k) {
                    if (k & 1) ret = 1ll * ret * a % p;
                    a = 1ll * a * a % p;
                    k >>= 1;
                }
                return ret;
            };
            long long l = find(p[0]), r = find(p[1]);
            if (l == r) {
                long long s = 0, c = get(l - 1);
                for (int i = 0; i <= 49; i++) {
                    if (l >> i & 1) {
                        c++;
                        if (c >= p[0] && c <= p[1]) s += i;
                    }
                }
                ans.push_back(qmi(2, s, p[2]));
            }
            else {
                long long s = 0, c = get(l - 1);
                for (int i = 0; i <= 49; i++) {
                    if (l >> i & 1) {
                        c++;
                        if (c >= p[0]) s += i;
                    }
                }
                c = get(r - 1);
                for (int i = 0; i <= 49; i++) {
                    if (r >> i & 1) {
                        c++;
                        if (c <= p[1]) s += i;
                    }
                }
                function<long long(long long)> get = [&](long long x) {
                    x++;
                    long long s = 0;
                    for (int i = 0; i <= 49; i++) {
                        long long c = x / (1ll << i + 1) * (1ll << i);
                        if (x % (1ll << i + 1) > 1ll << i) c += x % (1ll << i);
                        s += i * c;
                    }
                    return s;
                };
                if (l + 1 <= r - 1) s += get(r - 1) - get(l);
                ans.push_back(qmi(2, s, p[2]));
            }
        }
        return ans;
    }
};

 

参考资料

  第 130 场力扣夜喵双周赛 - 力扣(LeetCode):https://leetcode.cn/circle/discuss/FpYgO6/view/L5Vk47/

标签:Elements,big,二进制,Big,mid,long,queries,Array,sim
From: https://www.cnblogs.com/onlyblues/p/18189595

相关文章

  • SciTech-BigDataAIML-TensorFlow-Model: 模型建立与训练
    TensorFlow模型建立与训练TensorFlow模型建立与训练本章介绍如何使用TensorFlow快速搭建动态模型。模型的构建:tf.keras.Model和tf.keras.layers模型的损失函数:tf.keras.losses模型的优化器:tf.keras.optimizer模型的评估:tf.keras.metrics前置知识Python-{zh-......
  • LeetCode 1287. Element Appearing More Than 25% In Sorted Array
    原题链接在这里:https://leetcode.com/problems/element-appearing-more-than-25-in-sorted-array/description/题目:Givenanintegerarray sorted innon-decreasingorder,thereisexactlyoneintegerinthearraythatoccursmorethan25%ofthetime,returnthat......
  • 使用Arrays.asList()的坑
    背景在将数组转为list的时候,一般会使用到Arrays.asList()这个方法,但是在对转化后的list进行add操作的时候出现了java.lang.UnsupportedOperationException的报错原因Arrays.asList()方法只是将数组转换为一个固定长度的列表,它不支持增删操作。研究源码发现,它生成的ArrayLis......
  • SciTech-BigDataAIML-TensorFlow-Model的编译:设置(LossFunction+Optimizer+Metrics)与
    机器学习|model.compile()用法model.compile()的作用:为经过设计的Model(神经网络模型)设置好:loss损失函数、optimizer优化器、metrics准确性评价函数。并且进行编译;Optimizers优化器:Optimizer的主要功能是作用在GD(梯度下降)的过程,使得Gradient(梯度)更快(快速......
  • 终于明白了 Array.sort(comparator) 的原理
    终于明白了Array.sort(comparator)的原理原文地址:https://www.jameskerr.blog/posts/javascript-sort-comparators/After13yearsofJavaScript,IfinallyhaveawaytorememberhowthecomparatorfunctioninArray.sort()works.使用JavaScript13年之后,我终于有......
  • ArrayList in C#
    https://dotnettutorials.net/lesson/arraylist-collection-csharp/c#中的数组列表是什么?c#中的ArrayList是一个非泛型集合类,它的工作方式类似于数组,但提供了动态调整大小、从集合中间添加和删除元素等功能。c#中的ArrayList可以用来添加未知数据,也就是说,当我们不知道数据的类型......
  • 慎用 Arrays.asList
    Java8提供的Stream流式处理大大减少了集合类各种操作(投影、过滤、转换)的代码量,用起来非常香,所以在实际业务开发中,我们常常会把原始的数组转换为List类数据结构,使得其可以用上Stream流操作。Arrays.asList方法应该是各位最常用的数组一键转换为List的方法了,但这个方法......
  • 【java】ArrayList和LinkedList的区别
    一、ArrayList和LinkedList的相同点ArrayList和LinkedList都是实现了List接口的容器类,用于存储一系列的对象引用,他们都可以对元素的增删改查进行操作。ArrayList、LinkedList、Vector和Stack是List的四个实现类,List是一个接口,它继承与Collection接口,代表有序的队列。其中Vector......
  • 53_Maximum Subarray-最大子数组
    问题描述Givenanintegerarray nums,findthe subarray withthelargestsum,andreturn itssum.给定一个数组nums,找到一个子数组。使它的和最大,返回子数组例子Input:nums=[-2,1,-3,4,-1,2,1,-5,4]Output:6Explanation:子数组[4,-1,2,1]有最大的和6.基......
  • LeetCode 1186. Maximum Subarray Sum with One Deletion
    原题链接在这里:https://leetcode.com/problems/maximum-subarray-sum-with-one-deletion/description/题目:Givenanarrayofintegers,returnthemaximumsumfora non-empty subarray(contiguouselements)withatmostoneelementdeletion. Inotherwords,youwa......