Codeforces Round #407 (Div. 2) B+C!
B. Masha
and geometric depression
被这个题坑了一下午,感觉很水,一直WA在第14组,我那个气啊,结束后发现第14组有点小争议,于是找出题人解释,然后出题人甩给了我一段原文:Masha writes all progression terms one by one onto the board (including
repetitive) while condition |bi| ≤ l is
satisfied 嗯,看仔细看题很重要!
题意:给出你一个等比数列的首项和公比,然后给出一个范围l和n个数,求这个等比数列绝对值在这个范围内且不在这n个数中出现的有多少个,注意等比数列是一项一项写出的,当有某一项的绝对值不在这个范围内立即跳出。
思路:感觉是很简单的暴力模拟,然后无限WA,直接特判了公比为0、1、-1的情况,还是WA,看了后台才知道开始就应该特判首项与l的关系。//代码写的好丑啊,简直无法言说。
int main()
{
int m;
ll b,q,l;
while(~scanf("%I64d%I64d%I64d%d",&b,&q,&l,&m))
{
map<ll,int>q1;
ll x,r=l;
l=-l;
for(int i=0; i<m; i++)
{
scanf("%I64d",&x);
q1[x]=1;
}
if(abs(b)>r){ puts("0");continue;}
if(b==0)
{
if(q1[0]) puts("0");
else puts("inf");
continue;
}
int ans=0;
if(q==0)//公比为0
{
if(b==0)//全部为0
{
if(q1[0]) puts("0");
else puts("inf");
}
else//b不为0
{
if(!q1[0]) puts("inf");
else
{
if(q1[b]||b<l||b>r) puts("0");
else puts("1");
}
}
}
else if(q==1)
{
if(q1[b]||b<l||b>r) puts("0");
else puts("inf");
}
else if(q==-1)
{
ans=2;
if(q1[b]||b<l||b>r) ans--;
b=-b;
if(q1[b]||b<l||b>r) ans--;
if(ans) puts("inf");
else puts("0");
}
else //不会出现重复的
{
ans=0;
for(int i=1;; i++)
{
if(b>=l&&b<=r)
{
if(!q1[b]) ans++;
}
else break;
if(b<-INF||b>INF) break;
b*=q;
}
printf("%d\n",ans);
}
}
return 0;
}
这个C倒是很有意思的一道题,求子序列最大和。
题意:由题目所给的公式可以看出来,所有前后项的差的绝对值构成一个数列,然后选取一项作为起点第一项,奇数项加,偶数项减,选取的起点会影响加减符号。求最大值。
思路:做过连续最大和一眼就能看出本题关键,我们先预处理出这个差的绝对值序列,因为任意一项可加可减,具体看你选取的首项位置,所以我们先把所有的偶数项用来减,也就是偶数项都乘以-1,然后求一遍连续最大和,然后所有数都乘以-1,就反过来了,再求一遍连续最大和。答案就是过程中的最大值。
ll a[N];
int main()
{
int n;
while(~scanf("%d",&n))
{
for(int i=0; i<n; i++) scanf("%I64d",&a[i]);
for(int i=1; i<n; i++) a[i-1]=abs(a[i]-a[i-1]);//预处理差值序列
for(int i=0;i<n-1;i++) if(i%2) a[i]*=-1;
ll tmp=0,ans=0;
for(int i=0; i<n-1; i++)
{
if(tmp>=0) tmp+=a[i];
else tmp=a[i];
ans=max(ans,tmp);
}
tmp=0;
for(int i=0;i<n-1;i++) a[i]*=-1;
for(int i=0; i<n-1; i++)
{
if(tmp>=0) tmp+=a[i];
else tmp=a[i];
ans=max(ans,tmp);
}
printf("%I64d\n",ans);
}
return 0;
}
挺经典的一个题,对连续最大和有疑问可以做做:
http://acm.nyist.net/JudgeOnline/problem.php?pid=44
http://acm.hdu.edu.cn/showproblem.php?pid=1003(买一送一 http://acm.nyist.net/JudgeOnline/problem.php?pid=1320)
加强版:
http://acm.nyist.net/JudgeOnline/problem.php?pid=742
http://acm.nyist.net/JudgeOnline/problem.php?pid=104
Codeforces Round #407 (Div. 2) B+C!的更多相关文章
- Codeforces Round #407 (Div. 1) B. Weird journey —— dfs + 图
题目链接:http://codeforces.com/problemset/problem/788/B B. Weird journey time limit per test 2 seconds m ...
- Codeforces Round #407 (Div. 1)
人傻不会B 写了C正解结果因为数组开小最后RE了 疯狂掉分 AC:A Rank:392 Rating: 2191-92->2099 A. Functions again 题目大意:给定一个长度为 ...
- Codeforces Round #407 (Div. 2)
来自FallDream的博客,未经允许,请勿转载,谢谢. ------------------------------------------------------ A.Anastasia and ...
- Codeforces Round #407 (Div. 2)A B C 水 暴力 最大子序列和
A. Anastasia and pebbles time limit per test 1 second memory limit per test 256 megabytes input stan ...
- Codeforces Round #407 (Div. 2) D,E
图论 D. Weird journey time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
- Codeforces Round #407 (Div. 2) D. Weird journey(欧拉路)
D. Weird journey time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...
- 【分类讨论】Codeforces Round #407 (Div. 2) D. Weird journey
考虑这个二元组中有一者是自环,则必然合法. 考虑这两条边都不是自环,如果它们不相邻,则不合法,否则合法. 坑的情况是,如果它是一张完整的图+一些离散的点,则会有解,不要因为图不连通,就误判成无解. # ...
- 【预处理】Codeforces Round #407 (Div. 2) C. Functions again
考虑枚举每个子串开头的位置,然后答案转化成询问这个位置之后 哪个位置的前缀和 - 这位置的前缀和 最大(当然是已经把绝对值和正负的情况处理好了,可以发现按奇偶,这个序列只有两种情况),只需要预处理这两 ...
- 【分类讨论】【set】Codeforces Round #407 (Div. 2) B. Masha and geometric depression
模拟一下那个过程,直到绝对值超过l,或者出现循环为止. 如果结束之后,绝对值是超过l的,就输出当前写在黑板上的数量. 如果出现循环,则如果写在黑板上的数量非零,则输出inf(注意!如果陷入的循环是一个 ...
- 【贪心】Codeforces Round #407 (Div. 2) A. Anastasia and pebbles
贪心地一个一个尽可能往口袋里放,容易发现和顺序无关. #include<cstdio> #include<iostream> using namespace std; type ...
随机推荐
- java定时读取文件
在项目中经常会用到定时器,在笔试或者面试中也会经常问到定时器和IO流. public class TimerDemo { public static void main(String[] args) ...
- 【学习笔记】八:浏览器对象模型BOM
1.window对象 window是BOM的核心,它既是JS访问浏览器的一个接口,又是ES规定的Global对象. 1)全局作用域对象 a.所有在全局作用域中声明的变量.函数都会成为window对象的 ...
- eclipse版本要求修改
eclipse要求打开的是java1.6,而安装的是java1.7,这个时候需要修改配置 找到JAVA的安装路径, 点击前往-电脑-资源库-Java-javaVCirtualMachines-...- ...
- jmeter中通过beanshell访问eclipse中导出jar中的java类的方法
主要步骤 1.在eclipse中导出要引用的java代码为jar文件 2.将生成的jar文件放到jmeter的lib的ext目录下 3.在jmeter的jsr223处理器中导入要引用的java类型文件 ...
- HDU 4003 Find Metal Mineral (树形DP,经典)
题意:给定一棵树图,n个节点,有边权,要派k<11个机器人从节点s出发,遍历所有的点,每当1只机器人经过1条边时就会花费该边的边权,边是可重复走的.问遍历完所有点的最小花费? 思路: 非常经典, ...
- 洛谷 P2922 [USACO08DEC]秘密消息Secret Message
题目描述 Bessie is leading the cows in an attempt to escape! To do this, the cows are sending secret bin ...
- js 双向绑定
//双向绑定实例 <input name="" ng-bind-123="name" /> function DataBinder( object_ ...
- (十)mybatis之配置(mybatis-config.xml)
配置 可以从前篇的文章中知道(https://www.cnblogs.com/NYfor2018/p/9093472.html ),要使用mybatis需要以下配置: 1. mybatis-con ...
- docker配置国内镜像
1. 配置 root@ros-OptiPlex-3050:~# cat /etc/docker/daemon.json { "graph": "/mnt/docke ...
- 机器学习之-奇异值分解(SVD)原理详解及推导
转载 http://blog.csdn.net/zhongkejingwang/article/details/43053513 在网上看到有很多文章介绍SVD的,讲的也都不错,但是感觉还是有需要补充 ...