GT and sequence

 Accepts: 95
 Submissions: 1467
 Time Limit: 2000/1000 MS (Java/Others)
 Memory Limit: 65536/65536 K (Java/Others)
问题描述
给出NN个整数。你要选择至少一个数,使得你选的数的乘积最大。
保证任意选一些数相乘的绝对值都不会大于2^{63}-12​63​​−1。
输入描述
第一行读入一个数TT表示数据组数。
对于每组数据:
第一行是一个数NN,第二行是NN个整数。 1 \leq T \leq 10001≤T≤1000
1 \leq N \leq 621≤N≤62 hack时建议输出最后一行的行末回车;每一行的结尾不要输出空格。
输出描述
对于每组数据,输出一个数表示最大的乘积。
输入样例
1
3
1 2 3
输出样例
6

比的时候本来打算写一个刚学的深搜,结果最后TLE了。。。。

TLE代码:

#include <iostream>
#include <algorithm>
#include <cmath>
#include <vector>
#include <string>
#include <cstring>
#pragma warning(disable:4996)
using namespace std; int test;
long long n, a[70], ans, flag; void dfs(long long i, long long mul)
{
if (i == n + 1)
{
if (flag == 0 && mul == 1)
{
flag = 1;
}
else
{
ans = max(ans, mul);
}
return;
}
dfs(i + 1, mul);
dfs(i + 1, mul*a[i]);
} int main()
{
//freopen("i.txt", "r", stdin);
//freopen("o.txt", "w", stdout); int i;
scanf("%d", &test); while (test--)
{
flag = 0;
scanf("%I64d", &n); i = 1;
for (i = 1; i <= n; i++)
scanf("%I64d", &a[i]);
sort(a + 1, a + n + 1); ans = a[n];
dfs(1, 1); cout << ans << endl;
} //system("pause");
return 0;
}

最后规规矩矩考虑各种情况,很麻烦的一道题。。。。负数是奇数个的时候不要最大的那个。。。

代码:

#include <iostream>
#include <algorithm>
#include <cmath>
#include <vector>
#include <string>
#include <cstring>
#include <ctime>
#pragma warning(disable:4996)
using namespace std; long long po[900], ne[900];
long long n, num_ne, num_po; bool cmp(long long x, long long y)
{
return x > y;
} int main()
{ long long test, flag0, i, x, ans;
scanf("%I64d", &test); while (test--)
{
num_ne = 0;
num_po = 0;
flag0 = 0;
memset(po, 0, sizeof(po));
memset(ne, 0, sizeof(ne)); scanf("%I64d", &n); for (i = 1; i <= n; i++)
{
scanf("%I64d", &x);
if (x > 0)
{
po[num_po++] = x;
}
else if (x < 0)
{
ne[num_ne++] = x;
}
else
{
flag0 = 1;
}
}
sort(po, po + num_po);
sort(ne, ne + num_ne,cmp); if (flag0)
{
if (num_po > 0)
{
ans = 1;
for (i = 0; i < num_po; i++)
{
ans = ans*po[i];
}
if (num_ne % 2)
{
for (i = 1; i < num_ne; i++)
{
ans = ans*ne[i];
}
}
else
{
for (i = 0; i < num_ne; i++)
{
ans = ans*ne[i];
}
}
}
else
{
//没有正数的情况
if (num_ne == 0)
{
ans = 0;
}
else if (num_ne == 1)
{
ans = 0;
}
else
{
ans = 1;
if (num_ne % 2)
{
for (i = 1; i < num_ne; i++)
{
ans = ans*ne[i];
}
}
else
{
for (i = 0; i < num_ne; i++)
{
ans = ans*ne[i];
}
}
}
}
}
else
{
if (num_po > 0)
{
ans = 1;
for (i = 0; i < num_po; i++)
{
ans = ans*po[i];
}
if (num_ne % 2)
{
for (i = 1; i < num_ne; i++)
{
ans = ans*ne[i];
}
}
else
{
for (i = 0; i < num_ne; i++)
{
ans = ans*ne[i];
}
}
}
else
{
//没有正数的情况
if (num_ne == 0)
{
ans = 0;
}
else if (num_ne == 1)
{
ans = ne[0];
}
else
{
ans = 1;
if (num_ne % 2)
{
for (i = 1; i < num_ne; i++)
{
ans = ans*ne[i];
}
}
else
{
for (i = 0; i < num_ne; i++)
{
ans = ans*ne[i];
}
}
}
}
} cout << ans << endl;
}
return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

HDU 5504:GT and sequence的更多相关文章

  1. java中正则表达式,编译报错:Invalid escape sequence (valid ones are \b \t \n \f \r \" \' \\ )

    转自:https://www.cnblogs.com/EasonJim/p/6561666.html 若出现:Invalid escape sequence (valid ones are  \b   ...

  2. CocoaPods pod install的时候报错:invalid byte sequence in UTF-8 (ArgumentError)解决办法

    CocoaPods pod install的时候报错:invalid byte sequence in UTF-8 (ArgumentError)解决办法: 基本可以确定是Podfile中的内容编码有 ...

  3. HDU - 6409:没有兄弟的舞会(数学+思维)

    链接:HDU - 6409:没有兄弟的舞会 题意: 题解: 求出最大的 l[i] 的最大值 L 和 r[i] 的最大值 R,那么 h 一定在 [L, R] 中.枚举每一个最大值,那么每一个区间的对于答 ...

  4. POJ 3321:Apple Tree + HDU 3887:Counting Offspring(DFS序+树状数组)

    http://poj.org/problem?id=3321 http://acm.hdu.edu.cn/showproblem.php?pid=3887 POJ 3321: 题意:给出一棵根节点为1 ...

  5. JPA连接Mysql数据库时提示:Table 'jpa.sequence' dosen't exisit

    场景 在使用JPA连接Mysql数据库进行数据持久化时提示: Table 'jpa.sequence' dosen't exist 注: 博客主页: https://blog.csdn.net/bad ...

  6. hdu 5504 GT and sequence

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5504 GT and sequence Time Limit: 2000/1000 MS (Java/O ...

  7. HDU 5504 GT and sequence 模拟

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5504 思路:模拟 代码: #include<stdio.h>//------杭电5504 ...

  8. HDU 5950:Recursive sequence(矩阵快速幂)

    http://acm.hdu.edu.cn/showproblem.php?pid=5950 题意:给出 a,b,n,递推出 f(n) = f(n-1) + f(n-2) * 2 + n ^ 4. f ...

  9. HDU 2062:Subset sequence(思维)

    Subset sequence Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ...

随机推荐

  1. Vue入口页

    Template里面的App就是在这个实例里面注册的App组件 也就是整个过程就是将el所标识的元素替换成<App/> 而App就是在此实例注册的App组件.

  2. Linux centosVMware LNMP架构介绍、MySQL安装、PHP安装、Nginx介绍

    一. LNMP架构介绍 和LAMP不同的是,提供web服务的是Nginx 并且php是作为一个独立服务存在的,这个服务叫做php-fpm Nginx直接处理静态请求,动态请求会转发给php-fpm   ...

  3. js获取一个页面 是从哪个页面过来的

    document.referrer 获取来源页面的url console.log(document.referrer) if(document.referrer=="http://127.0 ...

  4. underscore.js -2009年发布的js库

    2009 Underscore.js 0.1.0发布 Underscore一个JavaScript实用库,提供了一整套函数式编程的实用功能,但是没有扩展任何JavaScript内置对象.它是这个问题的 ...

  5. RIFF

    RIFF全称为资源互换文件格式(Resources Interchange File Format),是Windows下大部分多媒体文件遵循的一种文件结构. RIFF文件所包含的数据类型由该文件的扩展 ...

  6. jstl.jar下载

    jakarta开源java项目 http://attic.apache.org/projects/jakarta.html 根据其官网信息项目已于2011年退休. 不过上面官方链接可以点击Downlo ...

  7. linux查漏补缺-linux命令行安装mysql

    apt安装 sudo apt-get update sudo apt-get install mysql-server root@192:/sys/fs/cgroup# apt-get install ...

  8. nmap 速查命令

    进行ping扫描,打印出对扫描做出响应的主机,不做进一步测试(如端口扫描或者操作系统探测) nmap -sP 192.168.1.0/24 仅列出指定网络上的每台主机,不发送任何报文到目标主机 nam ...

  9. Scrapy 使用 Item 封装数据、使用 Item Pipline处理数据

    1.Item 和 Field Scrapy 提供一下两个类,用户可以使用它们自定义数据类,封装爬取到的数据: (1)Item类 自定义数据类(如 BookItem)的基类 (2)Field 用来描述自 ...

  10. 任意两点之间的最短路(floyed)

    F.Moving On Firdaws and Fatinah are living in a country with nn cities, numbered from 11 to nn. Each ...