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 ...
随机推荐
- leetcode378 Kth Smallest Element in a Sorted Matrix
思路1: 使用堆. 实现: class Solution { public: int kthSmallest(vector<vector<int>>& matrix, ...
- P3375 【模板】KMP字符串匹配(全程注释,简单易懂)
题目描述 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.如果你不知道这是什么意思也不要问,去百度搜[ ...
- 遍历PspCidTable枚举进程
//测试环境:win7 32位 1 // DriverEntry.cpp #include "ntddk.h" #include <ntddvol.h> #includ ...
- MFC技术积累——基于MFC对话框类的那些事儿
1. 创建对话框类 (1)打开VC++6.0环境,点击:文件→新建: (2)在弹出的新建对话框中选择:工程→MFC AppWizard (exe)→输入工程名称(例如:功能调试)→工程保存路径名→确定 ...
- (八)mybatis之映射器
映射器 映射器是由Java接口和XML文件(或注解)共同组成的,作用如下: ① 定义参数类型. ② 描述缓存. ③ 描述SQL语句. ④ 定义查询结果和POJO的映射关系. 以下用两种 ...
- SAP产品的Field Extensibility
SAP开发人员的工作职责,除了实现软件的功能性需求外,还会花费相当的精力实现一些非功能性需求,来满足所谓的SAP Product Standard(产品标准).这些产品标准,包含在SAP项目实施中大显 ...
- 2017四川省赛E题( Longest Increasing Subsequence)
提交地址: https://www.icpc-camp.org/contests/4rgOTH2MbOau7Z 题意: 给出一个整数数组,F[i]定义为以i结尾的最长上升子序列,然后问以此删除掉第i个 ...
- 用valgrind检查内存问题
Valgrind Valgrind作为一个免费且优秀的工具包,平时大部分人可能都是使用valgrind检测内存问题,如内存泄露,越界等. Valgrind工具包包含多个工具,如Memcheck,Cac ...
- CPP-基础:非静态成员函数后面加const,以及mutable修饰成员变量
非静态成员函数后面加const(加到非成员函数或静态成员后面会产生编译错误),表示成员函数隐含传入的this指针为const指针,决定了在该成员函数中,任意修改它所在的类的成员的操作都是不允许的(因为 ...
- easyui树节点拖拽排序的存储过程
easyui树的拖拽排序功能 easyui树中有拖拽功能 树结构如下: 一个行政区域对应一个单位,一个单位对应多个部门,每个部门下有相关人员,功能要求: (1)行政区域没有子节点,点击text加载部门 ...