题目描述
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. Oracle中关于DateTime的一些描述

    转载自:http://www.cnblogs.com/fmxyw/archive/2008/08/26/1276850.html 在做话务报表,参考一下信息   to_date()与24小时制表示法及 ...

  2. percona xtradb cluster test

    docker run --rm -ti -e CLUSTER_NAME=test -e MYSQL_ALLOW_EMPTY_PASSWORD=1 --entrypoint="bash&quo ...

  3. GLSL in ShaderLab

    [Syntax] However, use of raw GLSL is only recommended for testing, or when you know you will only ta ...

  4. Unable to resolve module `../res/images/ic_popular.png`

  5. Linux显示文件前几行、拷贝文件前几行、删除文件前几列

    [一]显示文件前几行 ll -lrth:按照更改时间倒序排列,最新文件在下边 ll -lrSh:按照文件大小倒序排列,最大文件在下边 grep --color :高亮查询关键字 grep -A 10 ...

  6. Linux的作业管理

    一.作业管理的场景 作业管理(job control)是在bash环境下使用的,主要使用在同一个bash中管理多个作业的场景,譬如登录bash之后想同时复制文件.数据搜索,编译. 但是bash的作业管 ...

  7. 浅谈svn的hook机制

    一.什么是钩子 所谓svn的hook机制,就是用户在管理数据仓库的时候,当特定的事件发生时,相应的hook会被调用,hook 其实就相当于特定事件的处理函数. 当前 Subversion 提供了5种可 ...

  8. 使用 XML-RPC 为 C++ 应用程序启用 Web 服务

    http://www.ibm.com/developerworks/cn/webservices/ws-xml-rpc/ 引言 Internet 现在的受欢迎程度越来越高,由于这个原因及其固有的优势, ...

  9. 返回JSON到前台的对象属性设置

    1.项目中使用JSON的第三方架包:jackson-annotations-2.8.0.jar 2.可以将对象的属性返回进行相应的处理 比如格式化时间.密码敏感等属性 如:User.java pack ...

  10. laravel @if