给你一个N个整数的序列。

你应该选择一些数字(至少一个),并使它们的乘积尽可能大。

它保证你在初始序列中选择的任何数的乘积的绝对值不会大于263−1。 Input 在第一行有一个数字T(表示样例数)。

对于每个测试,第一行有一个数字N,下一行有N个数字。

1≤T≤1000 1≤N≤62

你最好在最后一行打印回车

你最好不要在每行的最后打印空格 Output 对于每个测试用例,输出答案。

  1. Sample Input
  2. 1
  3. 3
  4. 1 2 3
  5. Sample Output
  6. 6

思路

  • 就说一句:注意有没有0的情况,如果0,注意有多个0的情况,在有0的时候还要注意 只有一个负的情况(哎我咋那么菜 )

代码

  1. #include<iostream>
  2. #include<cmath>
  3. #include<cstdio>
  4. #include<queue>
  5. #include<cstring>
  6. #include<algorithm>
  7. #define ll long long
  8. #define inf 0x3f3f3f3f
  9. using namespace std;
  10. int read()
  11. {
  12. int res=0;char ch=0;
  13. while (!isdigit(ch))ch=getchar();
  14. while (isdigit(ch))res=(res<<3)+(res<<1)+(ch^48),ch=getchar();
  15. return res;
  16. }
  17. ll ar[100];
  18. int main()
  19. {
  20. /* freopen("A.txt","r",stdin); */
  21. int t;
  22. scanf("%d", &t);
  23. while(t --)
  24. {
  25. int cnt = 0;
  26. ll n;
  27. scanf("%lld", &n);
  28. ll val;
  29. ll ans = 1;
  30. bool have_z = 0;
  31. bool have_0 = 0;
  32. int have_f = 0;
  33. for(int i = 1; i <= n; i ++)
  34. {
  35. scanf("%lld", &val);
  36. if(val > 0)
  37. ans *= val, have_z = 1;
  38. else if(val < 0)
  39. ar[++ cnt] = val, have_f ++;
  40. else
  41. have_0 = 1;
  42. }
  43. if(n == 1)
  44. {
  45. printf("%lld\n", val);
  46. continue;
  47. }
  48. if(! have_z && have_0 && have_f <= 1)
  49. {
  50. printf("0\n");
  51. continue;
  52. }
  53. sort(ar + 1, ar + 1 + cnt);
  54. if(cnt % 2)
  55. {
  56. for(int i = 1; i < cnt; i ++)
  57. ans *= ar[i];
  58. }
  59. else
  60. {
  61. for(int i = 1; i <= cnt; i ++)
  62. ans *= ar[i];
  63. }
  64. printf("%lld\n", ans);
  65. }
  66. return 0;
  67. }

H - 蓬松的头发 HDU - 5504的更多相关文章

  1. hdu 5504 GT and sequence

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

  2. HDU 5504 GT and sequence 模拟

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

  3. H - Prince and Princess - HDU 4685(二分匹配+强连通分量)

    题意:有N个王子M个公主,王子喜欢一些公主,而且只能是王子喜欢的人,他们才可以结婚,现在让他们尽可能多的结婚的前提下找出来每个王子都可以和谁结婚. 分析:先求出来他们的最大匹配,因为给的数据未必是完备 ...

  4. 差分约束系统+(矩阵)思维(H - THE MATRIX PROBLEM HDU - 3666 )

    题目链接:https://cn.vjudge.net/contest/276233#problem/H 题目大意:对于给定的矩阵  每一行除以ai  每一列除以bi 之后 数组的所有元素都还在那个L- ...

  5. Day11 - H - Euclid's Game HDU - 1525

    Two players, Stan and Ollie, play, starting with two natural numbers. Stan, the first player, subtra ...

  6. Day9 - H - 最少拦截系统 HDU - 1257

    某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于 ...

  7. HDU 5504:GT and sequence

    GT and sequence  Accepts: 95  Submissions: 1467  Time Limit: 2000/1000 MS (Java/Others)  Memory Limi ...

  8. 树&图 记录

    A - Lake Counting POJ - 2386 最最最最最基础的dfs 挂这道题为了提高AC率(糖水不等式 B - Paint it really, really dark gray Cod ...

  9. 7/31 CSU-ACM2018暑期训练7-贪心

    比赛链接 A-CSU - 1588 现在有n堆果子,第i堆有ai个果子.现在要把这些果子合并成一堆,每次合并的代价是两堆果子的总果子数.求合并所有果子的最小代价. Input 第一行包含一个整数T(T ...

随机推荐

  1. Deepin环境下启动Pycharm没有启动图标解决办法

    小伙伴们在deepin下运行pycharm时,是不是需要通过sh文件启动? 下面告诉大家如何将pycharm图标放在桌面上: 1.在桌面打开终端,输入命令: sudo gedit /usr/share ...

  2. GitHub 热点速览 vol.10:疫情下的 GitHub

    作者:HelloGitHub-小鱼干 摘要:如果说上周的 GitHub 是股市附体 star 低迷不振,那么本周的 GitHub 像极了受到疫情影响而未开学的高校们,新生 GitHub 项少,能上 G ...

  3. 基于springboot1.5.9整合shiro时出现静态文件找不到的问题

    开门见山吧,上午对shiro进行整合了下,因为之前使用ssm框架对shiro框架整合过,所以觉得使用springboot再次对shiro框架进行整合也是没啥问题,但最后整合完之后,使用thymelea ...

  4. new Date在IE下面兼容问题

    昨天碰到一个bug,用art-template模板进行渲染时候,周视图任务展示失败,都是暂无任务,我以为是模板兼容问题,但最开始我用的时候记得就是IE8的兼容性问题,引入es5-shim.min.js ...

  5. Redis07——Redis到底能用在什么地方(下)

    在前一篇文章中,我们已经介绍过Redis的一些实际应用.如KV缓存.分布式锁.消息队列,由于篇幅原因,并未介绍完全.接下来将继续为各位带来Redis的更多应用. bitmat(位图) 实现 位图的基本 ...

  6. Ansible-1 基本认识及清单与模块

    ansible 一.常用的自动化运维工具 1.puppet 基于ruby开发,采用c/s架构,扩展性强,基于ssl,远程命令执行相对较弱, 2.saltstack 基于python开发,采用C/S架构 ...

  7. 序列化器:ModelSerializer

    ModelSerializer 类提供了一个快捷方式,可让你基于 Models 自动创建一个 Serializer 类,其中的字段与模型类字段对应. ModelSerializer 类与常规 Seri ...

  8. express模块中的req,res参数的常用属性方法

    express模块中的req,res参数的常用属性方法 const express = require('express'); const router = express.Router() rout ...

  9. 用 jQuery 实现表单验证(摘抄)——选自《锋利的jQuery》(第2版)第5章的例题 5.1.5 表单验证

    5.1.5 表单验证 表单(form)作为 HTML 最重要的一个组成部分,几乎在每个网页上都有体现,例如用户提交信息.用户反馈信息和用户查询信息等,因此它是网站管理者与浏览者之间沟通的桥梁.在表单中 ...

  10. flex 居中

    display: flex; justify-content: space-between; align-items: center;