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. Functions again

这个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!的更多相关文章

  1. 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 ...

  2. Codeforces Round #407 (Div. 1)

    人傻不会B 写了C正解结果因为数组开小最后RE了 疯狂掉分 AC:A Rank:392 Rating: 2191-92->2099 A. Functions again 题目大意:给定一个长度为 ...

  3. Codeforces Round #407 (Div. 2)

    来自FallDream的博客,未经允许,请勿转载,谢谢. ------------------------------------------------------ A.Anastasia and ...

  4. 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 ...

  5. Codeforces Round #407 (Div. 2) D,E

    图论 D. Weird journey time limit per test 2 seconds memory limit per test 256 megabytes input standard ...

  6. 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 ...

  7. 【分类讨论】Codeforces Round #407 (Div. 2) D. Weird journey

    考虑这个二元组中有一者是自环,则必然合法. 考虑这两条边都不是自环,如果它们不相邻,则不合法,否则合法. 坑的情况是,如果它是一张完整的图+一些离散的点,则会有解,不要因为图不连通,就误判成无解. # ...

  8. 【预处理】Codeforces Round #407 (Div. 2) C. Functions again

    考虑枚举每个子串开头的位置,然后答案转化成询问这个位置之后 哪个位置的前缀和 - 这位置的前缀和 最大(当然是已经把绝对值和正负的情况处理好了,可以发现按奇偶,这个序列只有两种情况),只需要预处理这两 ...

  9. 【分类讨论】【set】Codeforces Round #407 (Div. 2) B. Masha and geometric depression

    模拟一下那个过程,直到绝对值超过l,或者出现循环为止. 如果结束之后,绝对值是超过l的,就输出当前写在黑板上的数量. 如果出现循环,则如果写在黑板上的数量非零,则输出inf(注意!如果陷入的循环是一个 ...

  10. 【贪心】Codeforces Round #407 (Div. 2) A. Anastasia and pebbles

    贪心地一个一个尽可能往口袋里放,容易发现和顺序无关. #include<cstdio> #include<iostream> using namespace std; type ...

随机推荐

  1. AndroidStudio第一次提交项目代码到git服务器/github

    虽然使用AndroidStudio(以下简称as)开发并使用git管理代码已经有很长时间,但是第一次提交项目到git依然会很不顺利,网上的文章或许因为所使用版本比较老,并不一定完全凑效,因此写此笔记做 ...

  2. UIView和Masonry实现动画效果

    Masonry 实现动画效果如下: //button点击方法 - (void)clickedButton { static BOOL isMove; //默认是NO Weakify(weakSelf) ...

  3. Linux自带-系统级性能分析工具 — Perf(转)

    https://blog.csdn.net/zhangskd/article/details/37902159/

  4. 设置office首字母不变大小的手段

    选项->校对—〉自动更正选项->“自动更正”页,句首字母大写,取消就行了

  5. svn merge当主干修改后合并分支

    例如版本r1的主干创建分支r2,在r2上修改后得到r3,r1之后也修改得到r4,现在合并分支到主干上: 如果r3的修改和r4有冲突会提示出现冲突,因此不用担心主干合并后会被分支操作覆盖,因为这并不是简 ...

  6. php 小坑记录

    1 empty  PHP<=5.5不能用于判断一个表达式的执行结果并且netbeans 和eclipse编辑器识别不出来此错误 含有此用法的 类 和页面将会报错 empty($this-> ...

  7. bzoj 2658

    首先考虑容斥 我们计算出所有没有点在其中的矩形,然后用所有矩形减去这些矩形即可 然后考虑如何计算没有点在其中的矩形 采用扫描线的思想,从上向下一行一行扫,假设我们扫到的行编号是$a$,然后考虑如果左右 ...

  8. The - Modcrab——使用贪心策略

    一.题目信息 The - Modcrab 简单翻译一下:Vova有生命值h1,每次攻击值为a1,每瓶药水恢复生命值c1;Modcrab有生命值h2,每次攻击值为a2.在每个关卡开始,Vova有两种选择 ...

  9. CPP-基础:TCHAR

    目 录 定义 使用原理 1.定义 TCHAR是通过define定义的字符串宏[1] 2.使用原理 因为C++支持两种字符串,即常规的ANSI编码(使用""包裹)和Unicode编码 ...

  10. Python基础篇 -- 部分练习题

    实现一个整数加法计算器(两个数相加): 如:content = input("请输入内容:") 用户输入:5+9或5+ 9或5 + 9(含空白),然后进行分割转换最终进行整数的计算 ...