【a602】最大乘积
Time Limit: 1 second
Memory Limit: 32 MB
【问题描述】
一个正整数一般可以分为几个互不相同的自然数的,如3=1+2,4=1+3,5=1+4=2+3,6=1+5=2+4,…。
现在你的任务是将指定的正整数n分解成若干个互不相同的自然数的和,且使这些自然数的乘积最大。
【输入格式】
仅一行,正整数n(3≤n≤10000)。
【输出格式】
共两行。第一行是分解方案,相邻的数之间用一个空格分开,并且按从小到大的顺序。第二行是最大的乘积。
【输入样例】
10
【输出样例】
2 3 5
30
【题目链接】:http://noi.qz5z.com/viewtask.asp?id=a602
【题解】
注意这里是说分解成若干个不同的;不能有相同的;
首先考虑分解后的情况.
假设一个数字为h;
分解成两个部分a,h-a;
然后考虑它们的乘积与h的大小关系
令f(a)=a*(h-a)-h
=a*h-a*a-h
=(a-1)*h-a*a
这里让a< h/2(因为要不同嘛,就假设a< h-a呗->a< h/2)
则h>2*a
则f(a)>(a-1)*2a-a*a
->f(a)>a*a-2*a;
->f(a)>a(a-2);
也就是说如果a>=2的话
f(a)>a(a-2)>=0
即f(a)>0
也即a*(h-a)>h
所以如果分成的若干个不同的数,它们都大于1的话,那么分成的乘积肯定比原来的大;
这里;再展示一个事实;
设h=2*s
假设他分成了
s-1和s+1
那么乘积为s^2-1
如果分成了
s-2和s+2
那么乘积为s^2-4
也就是说分成的两个数a,b
它们的差的绝对值越小;
它们的乘积就相应地越大;
这样我们可以先选取连续的自然数
2,3,4,5….x
这里(2+x)*(x-1)/2<=n
然后令temp = n-(2+x)*(x-1)/2
如果tmep=0
那么因为是连续的自然数,那么它们的差肯定是最小的;(差都是1);
则直接输出2,3,4..x就好
如果temp>0;
那么就把temp平均地分配到前面的数字里面去;
当然你要从后往前一个一个地分配
比如
n=13
2 3 4
13-(2+3+4)=4
则分配两个1给4,然后2和3分别给它们分配一个1(在平均的情况下尽量先分配后面的)
->3 4 5
这样就能保证差的绝对值相对地小;
最后的成绩也就越大;
(在数学推导上的贪心?)
最后数字很大要写个高精度乘单精度;
(n=3和4的情况特判一下)
【完整代码】
#include <cstdio>
#include <iostream>
#include <vector>
using namespace std;
#define pb push_back
#define LL long long
const int MAXN = 100;
int n,now;
LL a[1000];
vector <LL> v;
int main()
{
scanf("%d",&n);
if (n==3 || n==4)
{
printf("%d %d\n%d",1,n-1,n-1);
return 0;
}
v.pb(2);n-=2;now=3;
while (n >= now)
{
n-=now;
v.pb(now);
now++;
}
now = v.size()-1;
while (n)
{
v[now]++;
now--;
n--;
if (now==-1)
now = v.size()-1;
}
a[1] = 1;
int le = 1,len = v.size();
for (int i = 0;i <= len-1;i++)
{
int x = 0;
for (int j = 1;j <= le;j++)
{
a[j] = a[j]*v[i] + x;
x = a[j]/10;
a[j]%=10;
}
while (x>0)
{
le++;
a[le] = x;
x = a[le]/10;
a[le]%=10;
}
}
for (int i = 0;i <= len-1;i++)
{
printf("%I64d",v[i]);
if (i==len-1)
puts("");
else
putchar(' ');
}
for (int i = le;i >= 1;i--)
printf("%I64d",a[i]);
return 0;
}
【a602】最大乘积的更多相关文章
- [LeetCode] Maximum Product Subarray 求最大子数组乘积
Find the contiguous subarray within an array (containing at least one number) which has the largest ...
- C语言 · 最小乘积(基本型)
问题描述 给两组数,各n个. 请调整每组数的排列顺序,使得两组数据相同下标元素对应相乘,然后相加的和最小.要求程序输出这个最小值. 例如两组数分别为:1 3 -5和-2 4 1 那么对应乘积取和的最小 ...
- 最大连续子序列乘积(DP)
题目来源:小米手机2013年校园招聘笔试题 题目描述: 给定一个浮点数序列(可能有正数.0和负数),求出一个最大的连续子序列乘积. 输入: 输入可能包含多个测试样例.每个测试样例的第一行仅包含正整数 ...
- 给定一个double类型的数组arr,其中的元素可正可负可0,返回子数组累乘的最大乘积。例如arr=[-2.5,4,0,3,0.5,8,-1],子数组[3,0.5,8]累乘可以获得最大的乘积12,所以返回12。
分析,是一个dp的题目, 设f[i]表示以i为结尾的最大值,g[i]表示以i结尾的最小值,那么 f[i+1] = max{f[i]*arr[i+1], g[i]*arr[i+1],arr[i+1]} ...
- CentOS 7 ssh脚本 求两个数值的“和”,“乘积”,”商“
1:在目录下创建一个 sh文件 touch 1.sh 2:进入sh文件书写sh脚本 #!/bin/bash read -p "请输入第一个数值" A read -p " ...
- NOIP2000乘积最大[序列DP]
题目描述 今年是国际数学联盟确定的“2000――世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得 ...
- n数乘积第m小
这是从Java贴吧看到的一道面试题,看了别人的解题思路实现的.... 如题: n个数,他们的乘积可得到一些其它的数,求第m小的. 输入格式: n m n1 n2 n3 ... 例: 输入: 3 8 2 ...
- 【wikioi】1017 乘积最大
题目链接 算法:划分型DP 非常典型的一道题目,划分型DP 题目描述: 设有一个长度为N的数字串,要求选手使用K个乘号将它分成K+1个部分,找出一种分法,使得这K+1个部分的乘积能够为最大.同时,为了 ...
- 最大乘积 Maximun Product
最大乘积 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=84562#problem/B 题意: 输入n个元素组成的序列s,你需要 ...
随机推荐
- R语言数据分析利器data.table包—数据框结构处理精讲
R语言数据分析利器data.table包-数据框结构处理精讲 R语言data.table包是自带包data.frame的升级版,用于数据框格式数据的处理,最大的特点快.包括两个方面,一方面是写的快,代 ...
- Oracle存储过程基本语法及基础教程
存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR REPLACE PROCEDURE ...
- 【python小随笔】进程池 multiprocessing.Pool的简单实现与踩过的坑
#导入进程模块 import multiprocessing #创建进程池 坑:一定要在循环外面创建进程池,不然会一直创建 pool = multiprocessing.Pool(30) for Si ...
- NPOI操作、导出Excel
//使用NPOI操作Excel private void ExcelNPOI(System.Data.DataTable dt, HttpContext context) { IWorkbook wo ...
- (四)IO流之InputStream和OutputStream
InputStream:定义了字节输入流的抽象类 OutputStream:定义了字节输出流的抽象类;该类所有方法返回void值 FileInputStream:继承InputStream FileO ...
- MacOS局域网访问Windows7共享文件
配置步骤 Windows7 进入[控制面板]-[网络和共享中心]-[高级共享设置] 启用网络发现 启用文件和打印机共享 选择要共享的文件或文件夹,点击[共享]-[特定用户] 选择Windows7当前登 ...
- jQuery $.isNumeric vs. $.isNaN vs. isNaN
在jQuery中,有几种方式可以判断一个对象是否是数字,或者可否转换为数字. 首先,jQuery.isNaN()在最新版本中已经被移除了(1.7之后),取而代之的是 jQuery.isNumeric ...
- 【uml】之用例图中的关系 标签: uml图形 2014-11-23 11:10 1422人阅读 评论(29)
用例图显示谁是相关的用户,用户希望系统提供什么样的服务(用例),用例之间的关系图,用例图主要的作用是获取需求.指导测试.所以,用例图是站在用户的角度来画的图,应该体现的是用户想要的功能,并不需要体现如 ...
- iOS 9适配系列教程:后台定位
http://www.cocoachina.com/ios/20150624/12200.html Demo:GitHub地址 [iOS9在定位的问题上,有一个坏消息一个好消息]坏消息:如果不适配iO ...
- CSS文本超过两行用省略号代替
1.只显示一行,超出部分用省略号 white-space: nowrap; overflow: hidden; text-overflow: ellipsis; 2.只显示两行(或多行),超出部分用省 ...