【leetcode】3524 求出数组的X值1

题目链接

题目描述

给你一个正整数数组 nums 和一个正整数 k。

你可以对数组执行一次操作:移除不重叠的前缀和后缀(可以为空),留下一个连续非空子数组。

对于每一种留下的子数组,计算:

(该子数组的乘积) % k = x

你需要统计所有可能的结果 x ∈ [0, k-1] 出现的次数,返回一个长度为 k 的数组 result,其中:

result[x] 表示得到 x 作为余数的方案数

解题思路

你可以移除任意前缀和后缀 ,留下的是一个非空的连续子数组。

也就是说:我们其实是统计所有子数组的乘积模 k 的结果分布

直接采用动态规划进行转移

java 复制代码
class Solution {
    public long[] resultArray(int[] nums, int k) {
        long[] ans = new long[k];
        long[] lurminexod = new long[k];

        for (int i : nums) {
            long[] newlurminexod = new long[k];
            
            for (int j = 0; j < k; j++) {
                int index = (int)(((long)j * i) % k);
                newlurminexod[index] += lurminexod[j];
            }
            newlurminexod[i % k]++;
            lurminexod = newlurminexod;

            for (int j = 0; j < k; j++) {
                ans[j] += lurminexod[j];
            }
        }

        return ans;
    }
}
相关推荐
I_LPL12 小时前
hot100贪心专题
数据结构·算法·leetcode·贪心
颜酱12 小时前
DFS 岛屿系列题全解析
javascript·后端·算法
WolfGang00732113 小时前
代码随想录算法训练营 Day16 | 二叉树 part06
算法
2401_8318249614 小时前
代码性能剖析工具
开发语言·c++·算法
Sunshine for you15 小时前
C++中的职责链模式实战
开发语言·c++·算法
qq_4160187215 小时前
C++中的状态模式
开发语言·c++·算法
2401_8845632415 小时前
模板代码生成工具
开发语言·c++·算法
2401_8319207415 小时前
C++代码国际化支持
开发语言·c++·算法
m0_6727033115 小时前
上机练习第51天
数据结构·c++·算法
ArturiaZ15 小时前
【day60】
算法·深度优先·图论