hdu4038贪心(最快上升倍率,好题)
题意:
给你n个数,然后有两种操作 1.给其中的一个数+1,2.在序列里面增加一个1,然后给你一个m,表示进行了m次操作,最后问你操作之后所有数乘积最大是多少?
思路:
徒弟给我的一个题目,感觉不错,这个题目细节比较多,至于难度,感觉还行,值得做一做,大体思路就是模拟,有点贪心的意思,首先我们要看看负数的个数,如果是奇数个,那么要把其中的一个绝对值最小的负数,也就是那个最大的负数变成正数,然后继续,如果是偶数个那么直接继续,接下来我们要把所有的0变成1,然后把所有的1变成2,然后把所有的2变成3,然后如果还有剩余步数,那么我们把他尽可能变成3,然后是2,如果这个时候还剩余怎么办?在剩余也就是肯定剩一个了,那么我们就把他加到当前的最小的那个数上,当前最小的那个数只有两种可能,要么是3,要么是比三大的数,这个自己想,上面的步骤中如果m在某个环节用没了,那么就停止然后统计答案就行了,下面说下,为什么3是关键呢?
我的想法是这样,我们可以考虑增加的倍率,如果是0那么+1这个肯定是最优的,如果是1增加1也是当前最合适的,因为直接增加一倍,继续往下会发现到3的时候在增加就没有直接在虚拟出来一个3合适了,大体是下面那样
1 > 0
2/1 * 2/1 > 2
3/2 * 3/2 * 3/2 > 3
4/3*4/3*4/3*4/3 < 4
我是这么推的 不知道对不对
然后就是细节,各种细节要注意,比如3^X,这个X目测很大,为了不超时建议快速幂,还有就是数据范围,还有就是负数取余的问题...
#include<stdio.h>
#include<algorithm>
#define MOD 1000000007
__int64 X[100005];
__int64 Pow(__int64 a ,__int64 b)
{
__int64 c = 1;
while(b)
{
if(b&1) c = c * a % MOD;
a = a * a % MOD;
b /= 2;
//printf("%I64d %I64d %I64d*\n" ,a ,b ,c);
}
return c;
}
int main ()
{
int t ,n ,cas = 1 ,i;
__int64 m ,Ans;
scanf("%d" ,&t);
while(t--)
{
scanf("%d %I64d" ,&n ,&m);
printf("Case %d: " ,cas ++);
__int64 sf = 0 ,s0 = 0 ,s1 = 0 ,s2 = 0 ,s3 = 0;
__int64 Max= 0 ,Maxid = -1;
__int64 Min = 0 ,Minid = -1;
for(i = 1 ;i <= n ;i ++)
{
scanf("%I64d" ,&X[i]);
if(X[i] >= 3 && Minid == -1 || Min > X[i])
{
Min = X[i];
Minid = i;
}
if(X[i] < 0)
{
sf ++;
if(Max == 0 || Max < X[i])
Max = X[i] ,Maxid = i;
}
if(X[i] == 0) s0 ++;
if(X[i] == 1) s1 ++;
if(X[i] == 2) s2 ++;
}
if(sf % 2)
{
if(m <= -Max)
{
X[Maxid] += m;
Ans = 1;
for(i = 1 ;i <= n ;i ++)
Ans = Ans * X[i] % MOD;
printf("%I64d\n" ,Ans);
continue;
}
s0 ++ ,m += Max;
}
else Maxid = -1;
if(m >= s0)
{
s1 += s0;
m = m - s0;
s0 = 0;
}
else
{
s1 += m;
s0 = s0 - m ;
m = 0;
}
if(m >= s1)
{
s2 += s1;
m = m - s1;
s1 = 0;
}
else
{
s2 += m;
s1 = s1 - m ;
m = 0;
}
if(m >= s2)
{
s3 += s2;
m = m - s2;
s2 = 0;
}
else
{
s3 += m;
s2 = s2 - m ;
m = 0;
}
s3 += m / 3;
s2 += m % 3 / 2;
Ans = 1;
if(m % 3 % 2)
{
if(s3)
{
s3 --;
Ans = 4;
}
else
for(i = 1 ;i <= n ;i ++)
if(i == Minid) X[i] ++;
}
if(s0)
{
printf("0\n");
continue;
}
Ans = Ans * Pow(2 ,s2) % MOD * Pow(3 ,s3) % MOD;
for(i = 1 ;i <= n ;i ++)
{
if(i == Maxid || X[i] == 0 || X[i] == 1 || X[i] == 2)
continue;
if(X[i] < 0) X[i] *= -1;
Ans = Ans * X[i] % MOD;
}
printf("%I64d\n" ,Ans);
}
return 0;
}
hdu4038贪心(最快上升倍率,好题)的更多相关文章
- grep之字符串搜索算法Boyer-Moore由浅入深(比KMP快3-5倍)
这篇长文历时近两天终于完成了,前两天帮网站翻译一篇文章“为什么GNU grep如此之快?”,里面提及到grep速度快的一个重要原因是使用了Boyer-Moore算法作为字符串搜索算法,兴趣之下就想了解 ...
- Hadoop3.0新特性介绍,比Spark快10倍的Hadoop3.0新特性
Hadoop3.0新特性介绍,比Spark快10倍的Hadoop3.0新特性 Apache hadoop 项目组最新消息,hadoop3.x以后将会调整方案架构,将Mapreduce 基于内存+io+ ...
- delphi-json组件,速度非常快,要比superobject快好几倍
delphi-json组件,速度非常快,要比superobject快好几倍https://github.com/ahausladen/JsonDataObjectshttp://bbs.2ccc.co ...
- OpenCV Haar AdaBoost源代码改进(比EMCV快6倍)
这几天研究了OpenCV源代码 Haar AdaBoost算法,作了一下改进 1.去掉了全部动态分配内存的操作.对嵌入式系统有一定的速度提升 2.凝视覆盖了大量关键代码 3.降低了代码一半的体积,而且 ...
- grep之字符串搜索算法Boyer-Moore由浅入深(比KMP快3-5倍)(转)
这篇长文历时近两天终于完成了,前两天帮网站翻译一篇文章“为什么GNU grep如此之快?”,里面提及到grep速度快的一个重要原因是使用了Boyer-Moore算法作为字符串搜索算法,兴趣之下就想了解 ...
- 一个比Spring Boot快44倍的Java框架!
最近栈长看到一个框架,官方号称可以比 Spring Boot 快 44 倍,居然这么牛逼,有这么神奇吗?今天带大家来认识一下. 这个框架名叫:light-4j. 官网简介:A fast, lightw ...
- 比MR至少快5倍的神器,竟然是它
Hive简介 Hive是一个基于 Hadoop 的开源数据仓库工具,用于存储和处理海量结构化数据.它最初是应Facebook对每天产生的海量新兴社会网络数据进行管理和机器学习的需求而产生和发展的,Hi ...
- MySQL 8.0 正式版 8.0.11 发布:比 MySQL 5.7 快 2 倍
ySQL 8.0 正式版 8.0.11 已发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能! 注意:从 MySQL 5.7 升级到 MySQL 8. ...
- Protobuf有没有比JSON快5倍?用代码来击破pb性能神话
转 http://www.sohu.com/a/136487507_505779 2017-04-26 07:58 程序设计 /58 /技术 导读:Google 的 Protocol Buffers ...
随机推荐
- HDOJ-6665(离散化+DFS求连通分量)
Calabash and Landlord HDOJ-6665 这里考察的是离散化的知识. 首先将所有的x坐标和y坐标放入两个数组中,然后对这两个数组进行排序.因为总共的坐标数就5个所以这两个数组的大 ...
- Microsoft Teams 最新功能发布:协作篇
正在进行的2021年的Microsoft Ignite大会,发布了一系列跟Microsoft Teams相关的新功能,英文介绍请参考 https://techcommunity.microsoft.c ...
- let、const、var区别?
let.const.var区别? let和const不存在变量提升(没有预解析,var有预解析). let和const在同一作用域范围内不能重复定义变量.(var可以). let和const有严格的作 ...
- Java数据持久层
一.前言 1.持久层 Java数据持久层,其本身是为了实现与数据源进行数据交互的存在,其目的是通过分层架构风格,进行应用&数据的解耦. 我从整体角度,依次阐述JDBC.Mybatis.Myba ...
- kubernetes生产实践之mongodb
简介 先看下生命周期图 kubedb支持的mongodb版本 [root@qd01-stop-k8s-master001 mysql]# kubectl get mongodbversions NAM ...
- Selenium 4.0beta:读源码学习新功能
Selenium 4 源码分析 这一篇文章我们来分析Selenium 4 python版源码. 除非你对Selenium 3的源码烂熟于心,否则通过对比工具分析更容易看出Selenium 4更新了哪些 ...
- java内部类 的理解
* 类的第5个成员:内部类 * 1.相当于说,我们可以在类的内部再定义类.外面的类:外部类.里面定义的类:内部类 * 2.内部类的分类:成员内部类(声明在类内部且方法外的) vs 局部内部类(声明在类 ...
- 浅析MyBatis(二):手写一个自己的MyBatis简单框架
在上一篇文章中,我们由一个快速案例剖析了 MyBatis 的整体架构与整体运行流程,在本篇文章中笔者会根据 MyBatis 的运行流程手写一个自定义 MyBatis 简单框架,在实践中加深对 MyBa ...
- 杨辉三角的实现(Java)
杨辉三角的实现 一.什么是杨辉三角 杨辉三角是二项式系数在三角形中的一种几何排列.每个数等于它上方两数之和.每行数字左右对称,由1开始逐渐变大.第n行的数字有n项.前n行共[(1+n)n]/2 个数. ...
- Balanced Diet Gym - 102220B
题目链接:https://vjudge.net/problem/Gym-102220B 题意:每组数据 给了 N和M表示有M种类型的糖果,这些糖果一共N个.接下了是 M 组数据,表示如果你选第 i 中 ...