Time Limit: 1 second

Memory Limit: 32 MB

【问题描述】

  1. 一个正整数一般可以分为几个互不相同的自然数的,如31+241+351+42+361+52+4,…。
  2. 现在你的任务是将指定的正整数n分解成若干个互不相同的自然数的和,且使这些自然数的乘积最大。

【输入格式】

  1. 仅一行,正整数n3n10000)。

【输出格式】

  1. 共两行。第一行是分解方案,相邻的数之间用一个空格分开,并且按从小到大的顺序。第二行是最大的乘积。

【输入样例】

  1. 10

【输出样例】

  1. 2 3 5
  2. 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的情况特判一下)



【完整代码】

  1. #include <cstdio>
  2. #include <iostream>
  3. #include <vector>
  4. using namespace std;
  5. #define pb push_back
  6. #define LL long long
  7. const int MAXN = 100;
  8. int n,now;
  9. LL a[1000];
  10. vector <LL> v;
  11. int main()
  12. {
  13. scanf("%d",&n);
  14. if (n==3 || n==4)
  15. {
  16. printf("%d %d\n%d",1,n-1,n-1);
  17. return 0;
  18. }
  19. v.pb(2);n-=2;now=3;
  20. while (n >= now)
  21. {
  22. n-=now;
  23. v.pb(now);
  24. now++;
  25. }
  26. now = v.size()-1;
  27. while (n)
  28. {
  29. v[now]++;
  30. now--;
  31. n--;
  32. if (now==-1)
  33. now = v.size()-1;
  34. }
  35. a[1] = 1;
  36. int le = 1,len = v.size();
  37. for (int i = 0;i <= len-1;i++)
  38. {
  39. int x = 0;
  40. for (int j = 1;j <= le;j++)
  41. {
  42. a[j] = a[j]*v[i] + x;
  43. x = a[j]/10;
  44. a[j]%=10;
  45. }
  46. while (x>0)
  47. {
  48. le++;
  49. a[le] = x;
  50. x = a[le]/10;
  51. a[le]%=10;
  52. }
  53. }
  54. for (int i = 0;i <= len-1;i++)
  55. {
  56. printf("%I64d",v[i]);
  57. if (i==len-1)
  58. puts("");
  59. else
  60. putchar(' ');
  61. }
  62. for (int i = le;i >= 1;i--)
  63. printf("%I64d",a[i]);
  64. return 0;
  65. }

【a602】最大乘积的更多相关文章

  1. [LeetCode] Maximum Product Subarray 求最大子数组乘积

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  2. C语言 · 最小乘积(基本型)

    问题描述 给两组数,各n个. 请调整每组数的排列顺序,使得两组数据相同下标元素对应相乘,然后相加的和最小.要求程序输出这个最小值. 例如两组数分别为:1 3 -5和-2 4 1 那么对应乘积取和的最小 ...

  3. 最大连续子序列乘积(DP)

    题目来源:小米手机2013年校园招聘笔试题 题目描述: 给定一个浮点数序列(可能有正数.0和负数),求出一个最大的连续子序列乘积. 输入: 输入可能包含多个测试样例.每个测试样例的第一行仅包含正整数 ...

  4. 给定一个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]} ...

  5. CentOS 7 ssh脚本 求两个数值的“和”,“乘积”,”商“

    1:在目录下创建一个  sh文件 touch 1.sh 2:进入sh文件书写sh脚本 #!/bin/bash read -p "请输入第一个数值" A read -p " ...

  6. NOIP2000乘积最大[序列DP]

    题目描述 今年是国际数学联盟确定的“2000――世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得 ...

  7. n数乘积第m小

    这是从Java贴吧看到的一道面试题,看了别人的解题思路实现的.... 如题: n个数,他们的乘积可得到一些其它的数,求第m小的. 输入格式: n m n1 n2 n3 ... 例: 输入: 3 8 2 ...

  8. 【wikioi】1017 乘积最大

    题目链接 算法:划分型DP 非常典型的一道题目,划分型DP 题目描述: 设有一个长度为N的数字串,要求选手使用K个乘号将它分成K+1个部分,找出一种分法,使得这K+1个部分的乘积能够为最大.同时,为了 ...

  9. 最大乘积 Maximun Product

    最大乘积 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=84562#problem/B 题意: 输入n个元素组成的序列s,你需要 ...

随机推荐

  1. golang数据类型三

  2. java中的volatile和synchronized

    关于volatile和同步相关的东西,网上有太多错误和解释不清的东西, 所以查阅相关书籍和文章后总结如下, 如果还是也存在不正确的内容,请一定要指出来, 以免误人子弟:) 1. 原子性与可视性 原子性 ...

  3. Contacts源码分析(一、概述)

    代码版本: Contact code version: 4.4.2 一 打开Log开关:如if (Log.isLoggable(Constants.PERFORMANCE_TAG, Log.DEBUG ...

  4. nginx设置301永久重定向

    https://blog.csdn.net/wzqzhq/article/details/53376501 比如说我的域名有多个,一个主域名www.zq110.com,多个次域名:www.aaa.co ...

  5. 25-3 requests模块的cookie和代理操作

    一.基于requests模块的cookie操作 引言:有些时候,我们在使用爬虫程序去爬取一些用户相关信息的数据(爬取张三“人人网”个人主页数据)时,如果使用之前requests模块常规操作时,往往达不 ...

  6. python 嵌套列表

  7. 是时候了解React Native了

    文章首发于简书,欢迎关注 随着科技的发展,手机开发也在向好的方向不停的转变.IOS和Android两大手机操作横空出世,称霸江湖.我们每开发一个手机软件最少都需要开发这两个终端. 两大操作系统都在不断 ...

  8. Git 进阶:10大技巧让你迅速提升

    1.Git自动补全 假使你使用命令行工具运行Git命令,那么每次手动输入各种命令是一件很令人厌烦的事情. 命令: cd ~ curl https://raw.github.com/git/git/ma ...

  9. Mysql 查询一天中每半小时记录的数量

    SELECT HOUR(e.time)as Hour,FLOOR(MINUTE(e.time)/30) as M, COUNT(*) as Count FROM error_log e WHERE e ...

  10. Python语言的特点