题目描述
zc去参加抽奖活动,在抽奖箱里有n个球,每个球上写着一个数字。一次抽取两个球,得分为两个球上的数的乘积。为了中大奖,zc想要知道他能得到的最大得分为多少。
输入
第一行为T,代表样例数。(1<=T<=10)
其中每组样例,第一个数为n,代表球的数量,接下来n个数s1,s2…,sn,代表球上的数字。(2<=n<=1e5,-4e9<=bi<=4e9)

输出
每组样例输出一行,输出一个数,代表zc得到的最大得分。(保证最大得分不小于0)
样例输入

2
3
1 2 3
3
-1 0 1

样例输出

6
0

AC代码

#include<cstdio>
#include<algorithm>
#include<iostream>
#include<cstring>
using namespace std;
typedef long long ll;
const int M=;
ll aa[],bb[],sum[];
ll aa1[],bb1[],sum1[];
ll a[M];
int main()
{
ll n,T;
cin>>T;
while(T--)
{
cin>>n;
ll i,j=,k=,p=,l=,l1=,l2=,l3=,l4=,lp=;
memset(a,,sizeof(a));
memset(aa,,sizeof(aa));
memset(bb,,sizeof(bb));
memset(sum,,sizeof(sum));
memset(aa1,,sizeof(aa1));
memset(bb1,,sizeof(bb1));
memset(sum1,,sizeof(sum1));
for(i=;i<n;i++)
scanf("%lld",&a[i]);
ll Max1=-,Max2=-,Min1=,Min2=;
for(i=;i<n;i++)
{
if(Max1<a[i])
{
k=i;
Max1=a[i];
}
if(Min1>a[i])
{
p=i;
Min1=a[i];
}
}
for(i=;i<n;i++)
{
if(i!=k)
{
if(Max2<a[i])
Max2=a[i];
}
if(i!=p)
{
if(Min2>a[i])
Min2=a[i];
}
}
Min1=-Min1;
Min2=-Min2;
if(Max1==)
aa[]=;
if(!Max2)
bb[]=;
if(Min1==)
aa1[]=;
if(Min2==)
bb1[]=;
while(Max1)
{
aa[l1++]=Max1%;
Max1/=;
}
while(Max2)
{
bb[l2++]=Max2%;
Max2/=;
}
for(i=;i<l1;i++)
for(j=;j<l2;j++){
sum[i+j]+=aa[i]*bb[j];
l=i+j;
}
for(i=;i<l;i++)
{
ll w=sum[i];
sum[i]=w%;
sum[i+]+=w/;
}
while(Min1)
{
aa1[l3++]=Min1%;
Min1/=;
}
while(Min2)
{
bb1[l4++]=Min2%;
Min2/=;
}
for(i=;i<l3;i++)
for(j=;j<l4;j++){
sum1[i+j]+=aa1[i]*bb1[j];
lp=i+j;
}
for(i=;i<lp;i++)
{
ll w=sum1[i];
sum1[i]=w%;
sum1[i+]+=w/;
}
int flag=;
if(lp>l) flag=;
else
{
for(i=;i<;i++)
{
if(sum[i]<sum1[i])
{
flag=;
break;
}
}
}
if(flag)
{
for(;lp>=;lp--) printf("%lld",sum1[lp]);
printf("\n");
}
else
{
for(;l>=;l--) printf("%lld",sum[l]);
printf("\n");
} }
return ;
}

问题 H: 抽奖活动(大数)的更多相关文章

  1. ASC(22)H(大数+推公式)

    High Speed Trains Time Limit: 4000/2000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) Su ...

  2. 20160219.CCPP体系详解(0029天)

    程序片段(01):ReplaceAll.c 内容概要:ReplaceAll #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #incl ...

  3. poj 1945 Power Hungry Cows A*

    Description:     就是给你一个数,你可以把它自乘,也可以把他乘或除以任意一个造出过的数,问你最多经过多少次操作能变换成目标数 思路:这题真的不怎么会啊.n = 20000,每一层都有很 ...

  4. Intel® QAT加速卡之加密、哈希操作流程和示例

    Intel QAT 加密API介绍 文章主要讲述了Intel QAT 加密API接口的说明,以及多种应用场景下的使用方法. 文章目录 Intel QAT 加密API介绍 1. 概述 1.1 会话(se ...

  5. 江西财经大学第一届程序设计竞赛 H题 求大数的阶乘

    链接:https://www.nowcoder.com/acm/contest/115/H 来源:牛客网 晚上,小P喜欢在寝室里一个个静静的学习或者思考,享受自由自在的单身生活. 他总是能从所学的知识 ...

  6. HDU - 6433: H. Pow (简答题,输出大数)

    There are n numbers 3^0, 3^1, . . . , 3^n-1. Each time you can choose a subset of them (may be empty ...

  7. c语言经典算法——查找一个整数数组中第二大数

    题目: 实现一个函数,查找一个整数数组中第二大数. 算法思想: 设置两个变量max1和max2,用来保存最大数和第二大数,然后将数组剩余的数依次与这两个数比较,如果这个数a比max1大,则先将max1 ...

  8. 杨氏矩阵:查找x是否在矩阵中,第K大数

    参考:http://xudacheng06.blog.163.com/blog/static/4894143320127891610158/ 杨氏矩阵(Young Tableau)是一个很奇妙的数据结 ...

  9. 蓝桥杯算法提高 P1001(大数乘法)

      算法提高 P1001   时间限制:1.0s   内存限制:256.0MB   当两个比较大的整数相乘时,可能会出现数据溢出的情形.为避免溢出,可以采用字符串的方法来实现两个大数之间的乘法. 具体 ...

随机推荐

  1. css垂直居中方案

    先介绍几种常见的垂直布局方式: 已知盒子具体宽度(宽度可以为百分比)(适用于居中浮动元素) 第一种: 给父元素相对定位,给子元素绝对定位 父布局 { position: relative; } 子布局 ...

  2. java实现最通俗易懂的01背包问题

    这几天一直在想背包问题,昨天还有个学长专门讲了,但是还是不是很理解,今天我终于想通了背包问题,其实只要理解了这个思路,不管用什么语言,肯定是能编出来的.下面我就来介绍一下背包问题. 1.题目描述: 有 ...

  3. jquery下的提交,点击按钮没反应,post方法不执行 JSON方式在FORM表单下不起作用

    jquery下的提交,点击按钮没反应,post方法不执行 JSON方式在FORM表单下不起作用

  4. 346. Moving Average from Data Stream数据窗口流中位数的数据结构设计

    [抄题]: Given a stream of integers and a window size, calculate the moving average of all integers in ...

  5. Python PyInstaller 打包报错:AttributeError: 'str' object has no attribute 'items'

    pyinstaller打包时报错:AttributeError: 'str' object has no attribute 'items' 网上查询,可能是setuptools比较老: 更新一下 p ...

  6. [Plan]计划

    1. scala 2. kafka 1. lua 2. openResty 1. 日志收集 - python 2. 代码生成 3. 权限系统

  7. [C++] decltype(auto) C++ 11 feature

    1 //C++ 11 feature template <class T1, class T2> auto getMultiply(T1 data1, T2 data2) -> de ...

  8. spark reduceByKey

    reduce(binary_function) reduce将RDD中元素前两个传给输入函数,产生一个新的return值,新产生的return值与RDD中下一个元素(第三个元素)组成两个元素,再被传给 ...

  9. 详解python包管理器pip安装

    pip对于使用python的朋友并不陌生,当你想安装python模块的时候一定会首先想到它.pip 是一个安装和管理 Python 包的工具 , 是 easy_install 的一个替换品. 今天来说 ...

  10. 比较C++、Java、Delphi声明类对象时候的相关语法

    同学们在学习的时候经常会遇到一些问题,C++.Java.Delphi他们到底有什么不一样的呢?今天我们来比较C++.Java.Delphi声明类对象时候的相关语法.希望对大家有帮助! C++中创建对象 ...