单词覆盖还原#洛谷

题目描述

一个长度为 l l l 的字符串中被反复贴有 boygirl 两单词,后贴上的可能覆盖已贴上的单词(没有被覆盖的用句点表示),最终每个单词至少有一个字符没有被覆盖。问贴有几个 boy 几个 girl

输入格式

一行被反复贴有 boygirl 两单词的字符串。

输出格式

两行,两个整数。第一行为 boy 的个数,第二行为 girl 的个数。

样例 #1

样例输入 #1

复制代码
......boyogirlyy......girl.......

样例输出 #1

复制代码
4
2

提示

数据保证, 3 ≤ l ≤ 255 3\le l\le255 3≤l≤255,字符串仅仅包含如下字符: .bgilory \texttt{.bgilory} .bgilory。

python 复制代码
data=input()
num_boy=0
num_girl=0
length=len(data)
step=0
while step <length:
    if data[step]=='.':
       step+=1
       pass
    else:
        if data[step] == 'b':
            num_boy += 1
            if data[step + 1] == 'o':
                if data[step + 2] == 'y':
                    step += 3
                    pass
                else:
                    step += 2
                    pass
                pass
            else:
                step += 1
                pass
            pass
        elif data[step] == 'o':
            num_boy += 1
            if data[step + 1] == 'y':
                step += 2
                pass
            else:
                step += 1
                pass
            pass
        elif data[step] == 'y':
            num_boy += 1
            step += 1
            pass
        elif data[step] == 'g':
            num_girl += 1
            if data[step + 1] == 'i':
                if data[step + 2] == 'r':
                    if data[step + 3] == 'l':
                        step += 4
                        pass
                    else:
                        step += 3
                        pass
                    pass
                else:
                    step += 2
                    pass
                pass
            else:
                step += 1
                pass
            pass
        elif data[step] == 'i':
            num_girl += 1
            if data[step + 1] == 'r':
                if data[step + 2] == 'l':
                    step += 3
                    pass
                else:
                    step += 2
                    pass
                pass
            else:
                step += 1
                pass
            pass
        elif data[step] == 'r':
            num_girl += 1
            if data[step + 1] == 'l':
                step += 2
                pass
            else:
                step += 1
                pass
            pass
        elif data[step] == 'l':
            num_girl += 1
            step += 1
            pass

print(num_boy)
print(num_girl)

整个单词整个单词的判断,出现一个片段就判断一次,剩下的片段直接跳过。虽然代码很冗长但是思想简单,一遍通过,不用调试就是十分舒服了,不过最好还是能用优秀的方法来简化一下代码

相关推荐
武帝为此几秒前
【专家系统介绍】
人工智能·算法
敲个大西瓜几秒前
flask ApI快速上手
python
@insist123几秒前
软件设计师-分治法核心原理与典型应用
算法·软考·软件设计师·软件水平考试
机器学习之心几秒前
PSO-SVR粒子群算法优化支持向量机回归+SHAP分析+新数据预测,MATLAB代码
算法·支持向量机·回归·pso-svr·灰狼算法优化支持向量机回归
浩瀚之水_csdn1 分钟前
【框架】flask路由深度解析
后端·python·flask
lars_lhuan1 分钟前
Go 方法
开发语言·后端·golang
灰色小旋风2 分钟前
力扣 12 整数转罗马数字 C++
开发语言·c++·leetcode
8Qi83 分钟前
环形链表刷题笔记(LeetCode热题100--141、142)
c语言·数据结构·c++·算法·leetcode·链表
Sagittarius_A*4 分钟前
图像去雾:从直方图增强到暗通道先验【计算机视觉】
图像处理·人工智能·python·opencv·计算机视觉·图像去雾·暗通道先验
zach01276 分钟前
神经符号系统驱动的宠物健康监测范式革命:基于安庆大观区多模态数据流的GEO精准引流拓扑重构
人工智能·python·重构·宠物