乘积最大问题

乘积最大

题目描述

给定 NN 个整数 A1,A2,⋯ANA1​,A2​,⋯AN​。请你从中选出 KK 个数,使其乘积最大。

请你求出最大的乘积,由于乘积可能超出整型范围,你只需输出乘积除以 109+9109+9 的余数。

注意,如果 X<0X<0,我们定义 XX 除以 109+9109+9 的余数是负(−X)(−X)除以 109+9109+9 的余数。

即:0−((0−x)%109+9)0−((0−x)%109+9)。

输入描述

输入格式:

第一行包含两个整数 N,KN,K。

以下 NN 行每行一个整数 AiAi​。

其中,1≤K≤N≤105,−105≤Ai≤1051≤K≤N≤105,−105≤Ai​≤105。

输出描述

输出一个整数,表示答案。

输入输出样例

示例

输入

复制代码
5 3
-100000
-10000
2
100000
10000

输出

复制代码
999100009

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 256M
复制代码
package apr28;
import java.util.Arrays;
import java.util.Scanner;

public class Test1 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        long mod = (int)1e9 +9;
        int N = sc.nextInt();
        int K = sc.nextInt();
        int[] a = new int[N];
        for (int i = 0; i < N; i++) {
            a[i] = sc.nextInt();
        }
        Arrays.sort(a);
        int r = N -1;
        long res = 1;
        if(K % 2 == 1){
            res = a[N - 1];K--;
            r--;
        }
        int sign = 1;
        if(res < 0)
            sign = -1;

        int l = 0;

        while (K > 0){
            long x = (long)a[r] * a[r - 1];
            long y = (long)a[l] * a[l + 1];
            if(x * sign > y * sign)
            {
                res = ((x % mod) *(res % mod)) % mod;
                r-=2;
            }
            else
            {
                res = ((y % mod) * (res % mod)) % mod;
                l+=2;
            }
            K-=2;
        }
        System.out.println(res % mod);
    }
}
相关推荐
Chen_harmony1 分钟前
一、数据结构概念和复杂度计算
数据结构
小欣加油21 分钟前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
尽兴-1 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度
Black蜡笔小新1 小时前
自动化AI算法训练服务器DLTM训推一体工作站赋能多行业智能化升级
人工智能·算法·自动化
怪兽学LLM2 小时前
LeetCode 438 找到字符串中所有字母异位词(Python 固定滑动窗口+字符计数解法)
python·算法·leetcode
满怀冰雪2 小时前
第04篇-双指针算法-从有序数组到回文判断的高频解法
java·算法
CC数学建模2 小时前
2026年江西省研究生数学建模竞赛1题:空间数据分析中的过拟合识别完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
leo__5202 小时前
MATLAB实现牧羊人算法
开发语言·算法·matlab
Gauss松鼠会2 小时前
【GaussDB】GaussDB SMP特性调优详解
java·服务器·前端·数据库·sql·算法·gaussdb
Tisfy2 小时前
LeetCode 3689.最大子数组总值 I:What The Medium
算法·leetcode·题解·贪心·模拟·脑筋急转弯