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. git clone fatal: unable to access 'https://github.com/carlon/demo.git/': Failed to connect to github.com port 443: Timed out

    $ git config --global http.proxy $ git config --global --unset http.proxy 虽然之前没有设置代理,但是不知道为什么执行以上代码之 ...

  2. IOS命名

    NS开头的名称不要出现. NS系统名称开头. 命名缩写只用于通用专业术语,如URL,不可自创命名缩写,如Ctr.Msg.命名宁可长一些,也不要难于理解. 是否在看别人代码时各种缩写而不知其所以然?简短 ...

  3. static心得

    TextClass text; 吉晨   static注意 只要显式调用一个类的某一个static变量,那么就会连带static块,所有static变量一起调用,哪怕不去new一个对象,这时候已经对这 ...

  4. DataModel doesn't have preference values

    mahout和hadoop实现简单的智能推荐系统的时候,出现了一下几个方面的错误 DataModel doesn't have preference values 意思是DataModel中没有找到初 ...

  5. 欧拉函数求在1-n-1与n互质的个数

    long long phi(long long x) { long long res=x,a=x,i; ;i*i<=a;i++) { ) { res=res/i*(i-); ) a=a/i; } ...

  6. 爬虫_python3_requests

    Requests 网络资源(URLs)撷取套件 改善Urllib2的缺点,让使用者以最简单的方式获取网络资源 可以使用REST操作(POST,PUT,GET,DELETE)存取网络资源 import ...

  7. ios之UITextfield

    //初始化textfield并设置位置及大小   UITextField *text = [[UITextField alloc]initWithFrame:CGRectMake(20, 20, 13 ...

  8. x220 OS X 10.10.4安装

    变色龙安装过程: 1.使用磁盘助手将按照盘写入独立的磁盘分区(AF格式,就是Apple的HPS格式): 2.安装启动时,用-v -f -x参数,分别为显示信息.重新build系统驱动.安全模式: 3. ...

  9. CONTEST1001 题解

    PROBLEM A 分析 这个题属于非常基础的输出问题,一般来说见到这种题可以直接复制粘贴即可. 讲解 没有什么详细说明的直接复制粘贴即可.这样不容易出错. 代码 #include <stdio ...

  10. 身为前端开发工程师,你需要了解的搜索引擎优化SEO.

    网站url网站创建具有良好描述性.规范.简单的url,有利于用户更方便的记忆和判断网页的内容,也有利于搜索引擎更有效的抓取您的网站.网站设计之初,就应该有合理的url规划. 处理方式: 1.在系统中只 ...