【记录】stl入门习题

链接:登录---专业IT笔试面试备考平台_牛客网

来源:牛客网

题目描述

牛牛喜欢跟字符串玩耍,他刚刚学会了一个新操作,将一个字符串x插入另一个字符串y中(包括放在开头和结尾)

牛牛认为如果一个串是好的当这个串能按照如下方法被构造出来:

一开始,有一个空串,然后执行0次或者若干次操作,每次操作将ab插入当前的字符串

根据上面的定义,ab, aabb, aababb都是好串,aab,ba,abbb并不是好串

现在给你一个字符串s,判断s是否是好串

输入描述:

复制代码
输入一行包含一个字符串,长度不超过50

输出描述:

复制代码
输出"Good" 或者 "Bad"

示例1

输入

复制

复制代码
ab

输出

复制

复制代码
Good

示例2

输入

复制

复制代码
aab

输出

复制

复制代码
Bad

示例3

输入

复制

复制代码
abaababababbaabbaaaabaababaabbabaaabbbbbbbb

输出

复制

复制代码
Bad

错解

一开始理解错误题目,认为输入的字符串必须是偶数项而且ab必须相连。

cpp 复制代码
# include <bits/stdc++.h>
using namespace std;

int main(){
    string str;
    cin>>str;
    
    bool isGood=true;
    
    if(str.length()%2!=0) isGood=false;
    else{
        for(int i=0;i<str.length()-1;i+=2){
            if(str[i]!='a'||str[i+1]!='b') {
                isGood=false;
                break;
            }
        }
    }
    
    if(isGood==true) cout<<"Good";
    else cout<<"Bad";
    return 0;  
}

输出一直报错百分之六十,参考其他题解,又仔细看了看题目,原来是字符串里面a和b的数目和顺序要对应。

正解

核心思想:遇到a入栈,遇到b出栈,此时如果栈空则bad;b处理完后,如果栈空,也为bad。

cpp 复制代码
# include <bits/stdc++.h>
using namespace std;

int main(){
    string str;
    stack<char> stk;
    cin>>str;
    bool isGood=true;
    
    for(int i=0;i<str.size();i++){
        if(str[i]=='a') stk.push('a');
        else{
            if(stk.empty()) {
                isGood=false;
                break;
            }
            stk.pop();
        }
    }
    if(!stk.empty()) isGood=false;
    
    if(isGood==true) cout<<"Good";
    else cout<<"Bad";
    return 0;  
}

break是必要的,否则会引起溢出。

相关推荐
0xDevNull1 小时前
Java反射机制深度解析:从原理到实战
java·开发语言·后端
小小亮011 小时前
Next.js基础
开发语言·前端·javascript
ALex_zry2 小时前
C++网络编程心跳机制与连接保活:长连接稳定性保障
开发语言·网络·c++
Amumu121382 小时前
Js:正则表达式(二)
开发语言·javascript·正则表达式
学嵌入式的小杨同学2 小时前
STM32 进阶封神之路(三十二):SPI 通信深度实战 —— 硬件 SPI 驱动 W25Q64 闪存(底层时序 + 寄存器配置 + 读写封装)
c++·stm32·单片机·嵌入式硬件·mcu·架构·硬件架构
米粒12 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
Sgf2272 小时前
ES8(ES2017)新特性完整指南
开发语言·javascript·ecmascript
好大哥呀3 小时前
C++ Web 编程
开发语言·前端·c++
ID_180079054733 小时前
小红书笔记评论 API,Python 调用示例与完整 JSON 返回参考
java·开发语言
Fuxiao___3 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#