HDU 5504:GT and sequence
GT and sequence
给出NN个整数。你要选择至少一个数,使得你选的数的乘积最大。
保证任意选一些数相乘的绝对值都不会大于2^{63}-1263−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的更多相关文章
- 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 ...
- CocoaPods pod install的时候报错:invalid byte sequence in UTF-8 (ArgumentError)解决办法
CocoaPods pod install的时候报错:invalid byte sequence in UTF-8 (ArgumentError)解决办法: 基本可以确定是Podfile中的内容编码有 ...
- HDU - 6409:没有兄弟的舞会(数学+思维)
链接:HDU - 6409:没有兄弟的舞会 题意: 题解: 求出最大的 l[i] 的最大值 L 和 r[i] 的最大值 R,那么 h 一定在 [L, R] 中.枚举每一个最大值,那么每一个区间的对于答 ...
- 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 ...
- JPA连接Mysql数据库时提示:Table 'jpa.sequence' dosen't exisit
场景 在使用JPA连接Mysql数据库进行数据持久化时提示: Table 'jpa.sequence' dosen't exist 注: 博客主页: https://blog.csdn.net/bad ...
- hdu 5504 GT and sequence
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5504 GT and sequence Time Limit: 2000/1000 MS (Java/O ...
- HDU 5504 GT and sequence 模拟
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5504 思路:模拟 代码: #include<stdio.h>//------杭电5504 ...
- 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 ...
- HDU 2062:Subset sequence(思维)
Subset sequence Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ...
随机推荐
- ubunut18.04 下安装 gitlab ce版,使用清华源
gitlab官方的ubuntu安装说明 https://about.gitlab.com/install/#ubuntu 该安装说明介绍的是gitlab-ee版本 按照该说明也能安装gitlab-ce ...
- uniGUI之TUniHiddenPanel(14)
TUniHiddenPanel是将不在界面上显示的 容器 控件. 只有uniDBGrid实际列才有对应的编辑控件,如果是外键列则无法设置 编辑控件. 里面的控件将不会 显示.将控件放入其中即可. ...
- [Linux] day02——什么是Linux
什么是linux? 一种操作系统计算机 = 硬件 +软件系统软件 = 内核 + 驱动应用软件 编程 上网 linux系统构成linux内核基本库 应用程序-------------------常见的操 ...
- 吴裕雄 Bootstrap 前端框架开发——Bootstrap 表单:静态控件
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Java经典算法50道题
[程序1]题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 月 数量 1 1 2 ...
- The problem: somthing wrong when my computer excute the command "git clone XXXX"
Error:git@github.com: Permission denied (publickey).fatal: Could not read from remote repository. Pl ...
- P1435 回文字串(LCS问题)
题目背景 IOI2000第一题 题目描述(题目链接:https://www.luogu.org/problem/P1435) 回文词是一种对称的字符串.任意给定一个字符串,通过插入若干字符,都可以变成 ...
- MyBatis Dao层的编写
传统的dao层编写 以前编写dao层,先新建一个包com.chy.dao,再写接口StudentDao: public interface StudentDao { public void inser ...
- NO23 Linux正则表达式结合三剑客企业级实践--取IP
企业实践: 一.取IP的方法(用三剑客): grep: awk: sed:虽有三种,但是思路是一样的,用到正则有些表达细节不一样而已. 分析: sed***: 课堂试题: |sed -nr 's#^. ...
- P1093 字符串A+B
1093 字符串A+B (20分) 给定两个字符串 A 和 B,本题要求你输出 A+B,即两个字符串的并集.要求先输出 A,再输出 B,但重复的字符必须被剔除. 输入格式: 输入在两行中分别给出 ...