【题解】K乘积
题目描述
有N个数,每个数的范围是[-50,50],现在你要从这N个数中选出K个,使得这K个数的乘积最大。
输入格式
  第一行,N和K。 1 <= N <= 50。  1 <= K <= 10。
  第二行,N个整数。
输出格式
一个整数。
输入样例
5 3
6  9  -5  -6  4
输出样例
270
题解
容易想到贪心策略:答案必有偶数个负数。则枚举负数数量在乘上剩下的非负数数量即可。这里用前缀积可以更快。
#include <iostream>
#include <algorithm>
#define MAX_N (50 + 5)
using namespace std;
int n, m;
int mid;
long long a[MAX_N];
 << );
int main()
{
    cin >> n >> m;
    ; i <= n; ++i)
    {
        cin >> a[i];
        ) ++mid;
    }
    sort(a + , a + n + );
    a[] = a[n + ] = ;
    ; i <= mid; ++i)
    {
        a[i] *= a[i - ];
    }
    for(register int i = n; i > mid; --i)
    {
        a[i] *= a[i + ];
    }
    ; i <= m && i <= mid; ++i)
    {
        if(m - i > n - mid) continue;
        ans = max(ans, a[i] * a[n - (m - i) + ]);
    }
    cout << ans;
    ;
}
参考程序
【题解】K乘积的更多相关文章
- 最大k乘积问题
		
68.最大k乘积问题 (15分)C时间限制:3000 毫秒 | C内存限制:3000 Kb题目内容:设I是一个n位十进制整数.如果将I划分为k段,则可得到k个整数.这k个整数的乘积称为I的一个k乘积. ...
 - 20-最大k乘积问题
		
/* 最大k乘积问题 题目内容: 设I是一个n位十进制整数.如果将I划分为k段,则可得到k个整数. ...
 - 最大 k 乘积问题 ( 经典区间DP )
		
题意 : 设 NUM 是一个 n 位十进制整数.如果将 NUM 划分为 k 段,则可得到 k 个整数.这 k 个整数的乘积称为 NUM 的一个 k 乘积.试设计一个算法,对于给定的 NUM 和 k,求 ...
 - 68.最大k乘积问题 (15分)
		
C时间限制:3000 毫秒 | C内存限制:3000 Kb题目内容:设I是一个n位十进制整数.如果将I划分为k段,则可得到k个整数.这k个整数的乘积称为I的一个k乘积.试设计一个算法,对于给定的I和 ...
 - dp之区间:最大k乘积
		
题目:给你一个n(1<=n<=15)位数,求将它分成m段,用m-1个*连接起来的最大乘积....... 思路:定义dp[i][j]为将前i位数分成j段的最大乘积,那么dp[i][j]==m ...
 - ACM ICPC 2018 青岛赛区 部分金牌题题解(K,L,I,G)
		
目录: K Airdrop I Soldier Game L Sub-cycle Graph G Repair the Artwork ———————————————————— ps:楼主脑残有点严 ...
 - 最大k乘积
		
思路:看到这道题,第一思路就要是动态规划,不要想着用啥暴力或者排列组合,只会搞得很复杂. 动态规划的思路是对这个整数,我们从后向前进行划分k个数字,我们知道对于划分后的最后一个整数,它的位数要保证前面 ...
 - LeetCoded第25题题解--K个一组翻转链表--java--链表
		
链表 单链表:链表中的每个元素实际上是一个单独的对象,而所有对象都通过每个元素的引用字段链接在一起. 双链表:与单链表不同的是,双链表的每个节点都含有两个引用字段. 链表优点 灵活分配内存空间 能在O ...
 - Java实现k个数乘(cheng)(自然数的k乘积问题)
		
k个数乘(cheng) 题目描述 桐桐想把一个自然数N分解成K个大于l的自然数相乘的形式,要求这K个数按从小到大排列,而且除了第K个数之外,前面(K-l)个数是N分解出来的最小自然数.例如:N=24, ...
 
随机推荐
- redis底层设计(三)——redis数据类型
			
今天我们来看一下redis的数据类型.既然redis的键值对可以保存不同类型的值,那么很自然就需要对键值对的类型进行检查以及多态处理.下面我们将对redis所使用的对象系统进行了解,并分别观察字符串. ...
 - SpringBoot分布式 - Dubbo+ZooKeeper
			
一:介绍 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务.它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护.域名服务.分布式同步.组服务等. Dubbo是Alib ...
 - Netty入门(二)之PC聊天室
			
参看Netty入门(一):Netty入门(一)之webSocket聊天室 Netty4.X下载地址:http://netty.io/downloads.html 一:服务端 1.SimpleChatS ...
 - Android开发之自定义万能BaseAdapter
			
话不多说哦,直接上模板: package com.zyzpp.adapter; import android.content.Context; import android.util.SparseAr ...
 - 使用C#创建SQLite控制台应用程序
			
本文属于原创,转载请注明出处,谢谢! 一.开发环境 操作系统:Windows 10 X64 开发环境:VS2015 编程语言:C# .NET版本:.NET Framework 4.0 目标平台:X86 ...
 - IT程序员的抉择:我要离开帝都了
			
不知不觉在北京已经漂泊了近5年了,共为3家公司打过工,其中有几十人的小公司,也有几万人的大公司.随着工作技能的提升和工作经验的积累,薪水自然也涨了不少,但是看着北京的房价.物价飞涨,感觉自己赚多少都是 ...
 - 617. Merge Two Binary Trees(Easy)
			
Given two binary trees and imagine that when you put one of them to cover the other, some nodes of t ...
 - H5 20-属性选择器上
			
20-属性选择器上 --> 我是段落1 我是段落2 我是段落3 我是段落4 我是段落5 <!DOCTYPE html> <html lang="en"> ...
 - 关于C语言内存的一些理解
			
内存这个大话题 key:心里一定要有内存的逻辑图. 程序是什么? 程序 = 代码 + 数据 代码放在Flash中代码段,可变的数据(全局变量.局部变量)放在内存中. 运行程序的目的是什么? 得到运行结 ...
 - 【转】Linux下cp: omitting directory `XXX'问题解决
			
在linux系统中复制文件夹时提示如下: Shell代码 [root@idtp4 site-packages]# /site-packages/ cp: omitting directory ‘yag ...