【NOIP练习赛】学习
【NOIP练习赛】T3、学习
Description
巨弱小 D 准备学习,有 n 份学习资料给他看,每份学习资料的 内容可以用一个正整数 ai 表示。小 D 如果在一天内学习了多份资料, 他只能记住这些资料的内容表示成的整数的最大公约数的部分。学习 若干份资料得到的收益是小 D 记下的内容之和,也就是学习的资料 数乘上这些资料内容的最大公约数。小 D 今天准备挑一段连续的资 料来学习,请你告诉他最大的收益是多少。
Input
第一行一个正整数 n,表示资料数。 接下来 n 个正整数 ai,分别表示每份资料的内容。
对于 20%的数据,n<=100;
对于 40%的数据,n<=1000;
对于 70%的数据,n<=100000;
对于 100%的数据,n<=500000,ai<=${10^9}$
Output
输出一个整数,表示答案。
Sample Input
5 30 60 20 20 20
Sample Output
80
Solution
应某人要求,来写题解
这道题还是有点难度,毕竟一个区间gcd,一直没想到解法,听dalao讲解后豁然开朗
确实本题只需边读边处理,在读入每个数时计算该数与前面所有数的gcd,又由gcd的一个小公式gcd(a,b,c)=gcd(gcd(a,b),c)所以我们只要用这个数和前面记录下的gcd再求出gcd就可以做到求区间[1..i],[2..i],[3..i]...,[i-1,i]的gcd
但是如果gcd重复太多,显然会T掉,而由于gcd(a,b,c)=gcd(gcd(a,b),c),则gcd(a,b)<=gcd(a,b,c)所以区间[1..i],[2..i],[3..i]...,[i-1,i]是单调不增的,那么我们就可以将gcd相同的数字合并,记录最左边的数(因为i为右端点,该点越左,gcd*区间长度就会越大)
那么为什么这样不会T呢?
因为我们这样处理的话,记录下的gcd都为a[i]的因数,而a[i]的因数不会超过${\log _2}a[i]$ 个,所以我们记录下的前面的gcd个数不会超过${\log _2}a[i]$ 个,只要暴力求,然后每次合并,并且每次更新最优解即可
还是挂程序吧
#include<cstdio>
#include<algorithm>
#define ll long long
using namespace std;
int n,d[],k,l[];
ll ans;
int gcd(int a,int b){return a%b== ? b:gcd(b,a%b);}
int main()
{
scanf("%d",&n);
scanf("%d",&d[]);
l[]=,k=,ans=d[];
for (int i=;i<=n;i++) {
int m;
scanf("%d",&m);
for (int j=;j<=k;j++) d[j]=gcd(d[j],m);
int po=;
for (int j=;j<=k;j++) if (d[po]!=d[j]) d[++po]=d[j],l[po]=l[j];
k=po;
if (d[k]!=m) d[++k]=m,l[k]=i;
for (int j=;j<=k;j++) ans=max(ans,(ll)d[j]*(i-l[j]+));
}
printf("%lld",ans);
return ;
}
【NOIP练习赛】学习的更多相关文章
- 【NOIP练习赛】开车
[NOIP练习赛]T2.开车 Description 老司机小 Q 要在一个十字路口指挥车队开车,这个十字路口可 以描述为一个 n*n 的矩阵,其中第 2 行到第 n-1 行都各有一道横向车 道,第 ...
- NOIP练习赛题目6
长途旅行 难度级别:A: 运行时间限制:3000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 JY 是一个爱旅游的探险家,也是一名强迫症患者.现在JY 想要在C ...
- NOIP练习赛题目5
小象涂色 难度级别:C: 运行时间限制:1000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 小象喜欢为箱子涂色.小象现在有c种颜色,编号为0~c-1:还有n个箱 ...
- NOIP练习赛题目3
魔兽争霸 难度级别:C: 运行时间限制:1000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 小x正在销魂地玩魔兽他正控制着死亡骑士和n个食尸鬼(编号1-n)去打 ...
- NOIP练习赛题目4
肥得更高 难度级别:C: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 自2009年以来,A.B站的历史就已经步入了农业变革的黎明期.在两站的 ...
- NOIP练习赛题目2
小K的农场 难度级别:C: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个 ...
- NOIP练习赛题目1
有些题目可能没做,如计算几何.恶心模拟. 高级打字机 难度级别:C: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 早苗入手了最新的高级打字机 ...
- POJ_2104_Kth_(主席树)
描述 http://poj.org/problem?id=2104 给出一个n个数的数列,m次询问,每次询问求区间[l,r]中第k小的数,无修改操作. K-th Number Time Limit: ...
- OI知识点|NOIP考点|省选考点|教程与学习笔记合集
点亮技能树行动-- 本篇blog按照分类将网上写的OI知识点归纳了一下,然后会附上蒟蒻我的学习笔记或者是我认为写的不错的专题博客qwqwqwq(好吧,其实已经咕咕咕了...) 基础算法 贪心 枚举 分 ...
随机推荐
- C++ <queue>用法
C++队列可以不需要自己写,有现成的模版类 头文件: #include <queue> #include <iostream> using namespace std; (之前 ...
- python 基础知识及运算符
可变类型:列表.字典 不可变类型:整形.字符串.元组 标示符: 1.字母数字和下划线组成 2.不能以数字开头 3.区分大小写 4.不能以保留字命名 变量: 1.用描述性的单词命名变量,不要用保留字.汉 ...
- 关于ajax跨域请求API数据的一些问题
一般来说我们使用jquery的ajax来跨域请求API数据的时候每次请求,就只能请求一组数据,而且当我们再次点击发送ajax请求的时候,新请求的数据会覆盖掉原来的数据,那么如何每次在请求的数据的时候, ...
- uva 1444 Knowledge for the masses
uva 1444 Description You are in a library equipped with bookracks that move on rails. There are ma ...
- Spring MVC学习总结(10)——Spring MVC使用Cors跨域
跨站 HTTP 请求(Cross-site HTTP request)是指发起请求的资源所在域不同于该请求所指向资源所在的域的 HTTP 请求.比如说,域名A(http://domaina.examp ...
- zoj 3812 状压dp
转载:http://blog.csdn.net/qian99/article/details/39138329 题意:给出n个物品,每个物品有两种属性Wi,Ti,有q组查询,每组查询要求在n个物品中选 ...
- PHP rand()和mt_rand()的区别
rand()和mt_rand()作用都是产生一个随机整数,都有两种使用形式: 1.int rand(void) / int mt_rand(void) 2.int rand(int $min, int ...
- 非常适合新手的jq/zepto源码分析02
function isPlainObject(obj) { return isObject(obj) && !isWindow(obj) && Object.getPr ...
- 《WF in 24 Hours》读书笔记 - Hour 1 - Understanding Windows Workflow Foundation
1.1 Hour 1 - Understanding Windows Workflow Foundation 1.1.1 What workflow is in general A workflo ...
- C#文件运行类的VB.NET版本号
主要差别在于事件处理要採用AddHandler和RemoveHandler,以及AddressOf三个keyword,其他基本一样. VB的操作稍微繁琐.但仍然能够实现.