禁咒检验

                                   (3MB / 2s)
【问题描述】
  在古老的世界里,有一个神奇的职业叫做魔法师。
  魔法师的特点是会魔法,施放魔法需要念咒语。
  在古老的世界里,有一个神奇的职业叫做码农。码农的工作是帮助魔法师记录咒语。
  码农用 0 和 1 来记录咒语, 所以一个咒语可以用一个仅由 0 和 1 构成的字符串 S 表示。
  魔法师念咒语时就是把 S 从左到右读一遍。随着 0 和 1 的默念,魔法的能量从魔法师体内涌出。

  如果魔法师连续念的 4 个字符中, ‘0’的数量不到 2 个,那么魔法师的体力
会大量消耗。如果魔法师念 S 时会出现大量消耗体力的情况,那么 S 就被称为
禁咒。例如“010101”不是禁咒,但“001101000”是禁咒,因为魔法师会在连
续念出“1101” 。
  码农的一个重要任务,就是帮助魔法师判断一条咒语是不是禁咒。
因为在古老的世界里,还没有印刷术,更没有计算机,所以信息存储全靠手
写,所以如果 S 很长,码农是不会把 S 抄下来的,只会去背下一部分。相应的,
本题的内存仅能使用 3MB 。为避免程序运行时的额外内存计入这 3MB,评测时
会开 6MB, 但是你仍应当成 3MB 来写代码, 只是不必担心系统抢你仅有的 3MB
内存。
【输入格式】

一行一个字符串 S,表示咒语

【输出格式】

如果 S 是禁咒,输出“Yes” ,否则输出“No”

【样例输入】

100010101

【样例输出】
  No

【数据规模和约定】
对于 60%的数据, 1<=|S|<=1000
对于 100%的数据, 1<=|S|<=10^7

考场解题:
  这明显的在线做啊,用两个 int 变量记录一下,int a 表示 1 的
出现,int b 表示 0 的出现,若 b=2 是让 a 和 b 归零,若 a=3 了,则
判断一下 b 是不是小于 2,若小于 2 则输出‘Yes’ ,or 输出‘No’ ;
自己手造了几组样例,嗯,没毛病,感觉挺对的,就没再继续想。
then吃完饭回来,自己脑袋忽然灵光一闪,给自己举出了一个反例,

果然好像有 WA 的(0110100)

正解:
  好像我想麻烦了哦,直接定义一个 char a[5]数组,若字符串的
长度大于 4 后,每输入一个字符,对它和它之前三个字符统计一下 1
的数量,若数量超过了 3 个,则可以直接 break 掉,输出‘Yes’ ,输
入完以后没有 break 则输出‘No’就好咯。

哇,原来开 2s 是因为这啊,挺简单的,考场上咋就没想到呢。

据老师自己说没有准备卡 scanf,结果最后一个
  点还是卡了,getchar()就可以过。

  期望的分:100
   实际得分:60

代码:

#include <cstdio>
#include <iostream>
#include <queue>
#include <vector>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <set>
#include <map>
//#define DEBUG
using namespace std;
int main()
{
freopen("str.in","r",stdin);
freopen("str.out","w+",stdout);
queue<char>str;
int zero(),one();
bool ok(false);
char ch(getchar());
for(;ch == '' || ch == '';ch = getchar())
{
str.push(ch);
//cout<<ch;
if(ch == '')
{
++zero;
}
if(str.size() == )
{
if(zero < )
{
ok = true;
break;
}
if(str.front() == '')--zero;
str.pop();
}
}
if(ok)printf("Yes\n");
else printf("No\n");
return ;
}

5.1 qbxt 一测 T1的更多相关文章

  1. NOI十连测 第六测 T1

    思路: 用treap动态维护,记一个sum1,sum2,注意!,写treap如果有删除操作,千万不能把权值相同的分开来..,这在删除的时候会进入死循环,这是一个惨痛的教训... #include< ...

  2. NOI十连测 第五测 T1

    #include<cstdio> #include<cstring> #include<cmath> #include<iostream> #inclu ...

  3. NOI十连测 第四测 T1

    思路:首先每个蚂蚁移速相同,而且碰到就转头,这其实等价于擦肩而过! 看到2n个数互不相同就觉得方便多了:枚举每个数字往左或者往右作为最慢,然后考虑其他蚂蚁有多少种走路方向. (1),走的距离大于m/2 ...

  4. NOI十连测 第三测 T1

    这么二逼的题考试的时候我想了好久,我真是太弱了... 首先,由于ans都乘上了i*(i-1)/2,实际上要求的就是每个数的所有可能出现次数*这个数的权值. 我们发现,每个数的本质是一样的,我们记一个s ...

  5. BZOJ NOI十连测 第二测 T1

    出题人居然是个哲学家.. 26%的程序,太SB了...本来我的想法也是二分+贪心,但是贪心是个怪怪的SX贪心.. #include<algorithm> #include<cstdi ...

  6. BZOJ NOI十连测 第一测 T1

    思路:首先考虑t=1的情况,t等于1,那么所有位置的颜色相同,我们不用考虑概率的问题,那么,k+d*x在模d下都相等,我们考虑预处理一个数组s[i][j],代表d为i,起始位置为j的等差数列的和,这个 ...

  7. 5.1 qbxt 一测 T3

    反物质[问题描述] 物理学家有一种假设,世界上存在反物质,反物质遇到正常的物质会发生湮灭. 假设现在有 n 个粒子,每个粒子的种类用一个 m 以内的正整数表示.现在要将这些粒子按一定顺序放入一个封闭空 ...

  8. 5.1 qbxt 一测 T2

    求和[问题描述] 组合数 C(n,m)是从 n 个物品中取 m 个的方案数. C(n,m)=(n!)/(m!(n-m)!) 斐波那契数列 F 满足,F[0]=F[1]=1,n≥2 时 F[n]=F[n ...

  9. Test 17

    BZ OI 队测 T1: 题目大意: 喵星系有n个星球,标号为1到n,星球以及星球间的航线形成一棵树. 所有星球间的双向航线的长度都为1.小昕要在若干个星球建矿石仓库,设立每个仓库的费用为K.对于未设 ...

随机推荐

  1. 【WIP】客户端JavaScript Web Object

    创建: 2017/10/11   更新: 2017/10/14 标题加上[WIP],增加[TODO] 更新: 2018/01/22 更改标题 [客户端JavaScript Web Object, UR ...

  2. iOS中音频的录制与播放(本地音频文件的播放)

    iOS功能开发涉及到音频处理时,最常见的时进行录音,以及音频文件的播放.停止播放等的操作.在开发中还要避免同一个音频文件,或不同音频文件之间的处理,比如说正在播放A音频时,可以停止播放A音频,也可以播 ...

  3. Moctf--Pubg题目

    假期举办的一场比赛,开始的题目比较基础,misc神马的都还好说,就是web有些坑了,比如我今天要写的这一道题目.不过大佬说很简单..不过最后我还是解出来了,把思路放在这里. 打开之后得到这个页面,在网 ...

  4. 51nod 1119【杨辉三角】

    思路: = =杨辉三角的应用,组合数的应用: C(N+M,N); 逆元一发,费马小定理,OK. #include <stdio.h> #include <string.h> # ...

  5. NOIp2016 蚯蚓 【二叉堆/答案单调性】By cellur925

    题目传送门 $Sol$ $50pts$:我们考虑$q==0$的情况,每次在所有的蚯蚓中找到一只长度最大的,这非常二叉堆.所以我们可以用一个优先队列,随便水一下就有50分.($NOIp$的分真这么好拿? ...

  6. CF580D Kefa and Dishes 【状压dp】By cellur925

    题目传送门 友情链接:new2zydalao%%%  一篇优秀的状压文章 题目大意:$n$个菜有$k$个规则,如果kefa在吃完第$xi$个菜之后吃了第$yi$个菜(保证$xi$.$yi$不相等), ...

  7. python 蓝牙模块pybluz安装

    最近项目运用了蓝牙,所以来学一学蓝牙. 经过查阅,知道python的蓝牙模块是pybluz,然后老管理进行安装 出错,提示“Could not find the Windows Platform SD ...

  8. hdu 2189 悼念512汶川大地震遇难同胞——来生一起走 基础母函数

    #include <iostream> #include <algorithm> #include <cstring> using namespace std; ] ...

  9. RobotFramework自动化测试框架(2)- RobotFramework语法

    RobotFramework测试用例是由四部分组成的,下面就从这四个部分简单介绍语法: 关键字表 *** Keywords *** 设置表 *** Settings *** 变量表 *** Varia ...

  10. Qt文本读写之二:目录操作

    一.简介 QDir类用来访问目录结构及其内容,可以操作路径名.访问路径和文件相关信息以及操作底层的文件系统,还可以访问Qt的资源系统.Qt使用"/"作为通用的目录分隔符和URLs的 ...