乘积最大问题

乘积最大

题目描述

给定 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);
    }
}
相关推荐
BothSavage5 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn5 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽7 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法