当前位置: 首页 > news >正文

萧山网站建设那家好最近大事件新闻

萧山网站建设那家好,最近大事件新闻,ps做网站首页怎么,手机怎么做bt种子下载网站AcWing《蓝桥杯集训每日一题》—— 3768. 字符串删减 文章目录AcWing《蓝桥杯集训每日一题》—— 3768. 字符串删减一、题目二、解题思路三、代码实现本次博客我是通过Notion软件写的,转md文件可能不太美观,大家可以去我的博客中查看:北天的 …

AcWing《蓝桥杯集训·每日一题》—— 3768. 字符串删减

文章目录

  • AcWing《蓝桥杯集训·每日一题》—— 3768. 字符串删减
  • 一、题目
  • 二、解题思路
  • 三、代码实现

本次博客我是通过Notion软件写的,转md文件可能不太美观,大家可以去我的博客中查看:北天的 BLOG,持续更新中,另外这是我创建的编程学习小组频道,想一起学习的朋友可以一起!!!

一、题目

现在,需要删掉其中的一些字母,使得字符串中不存在连续三个或三个以上的 x

请问,最少需要删掉多少个字母?

如果字符串本来就不存在连续的三个或三个以上 x,则无需删掉任何字母。

输入格式

第一行包含整数 nnn

第二行包含一个长度为 nnn 的由小写字母构成的字符串。

输出格式

输出最少需要删掉的字母个数。

数据范围

3≤n≤1003≤n≤1003n100

输入样例1:

6
xxxiii

输出样例1:

1

输入样例2:

5
xxoxx

输出样例2:

0

输入样例3:

10
xxxxxxxxxx

输出样例3:

8

二、解题思路

  1. 暴力枚举法:

    我们可以通过枚举所有长度为3的子串,判断是否为 ‘xxx’,从而找到需要删除的字符数量。具体实现方法是从下标2开始,每次取出以该下标为结尾的长度为3的子串,判断是否为 ‘xxx’,如果是,就需要删除中间那个字符,即下标为i-1的字符。最后统计需要删除的字符数量即可。暴力枚举法的时间复杂度为 O(n)O(n)O(n),空间复杂度为 O(1)O(1)O(1)

  2. 双指针法:

    我们可以通过维护两个指针 i 和 j,其中 i 指向当前处理的字符,j 指向最近一个不需要删除的字符。具体实现方法是遍历整个字符串,如果当前字符为 ‘x’,就将 cnt 加 1,如果 cnt 等于 3,说明需要删除当前字符,即将 res 加 1,如果 cnt 大于 3,说明当前字符需要删除,但是删除后会导致字符串中存在连续三个 ‘x’,因此需要将 j 后移一位,即将 j 赋值为 i-1,同时将 cnt 减 1,这样可以保证删除当前字符后,字符串中不存在连续三个 ‘x’。如果当前字符不为 ‘x’,则将 cnt 置为 0,j 赋值为 i。最后统计需要删除的字符数量即可。时间复杂度为 O(n)O(n)O(n),空间复杂度为 O(1)O(1)O(1)

总体而言,双指针法的效率更高,因为其只需要遍历一遍字符串,而暴力枚举法需要枚举所有长度为 3 的子串,效率相对较低。

三、代码实现

n = int(input())
st = input()
c = 0
# 枚举所有长度为 3 的子串
for i in range(2, n):# 判断是否为 'xxx'if st[i - 2:i + 1] == 'xxx':# 如果是,则需要删除中间那个字符,即下标为 i-1 的字符c += 1
# 输出需要删除的字符数量
print(c)

双指针法代码实现:

n = int(input())
s = input()res, cnt = 0, 0
j = -1
# 遍历整个字符串
for i in range(n):# 如果当前字符为 'x'if s[i] == "x":# 将 cnt 加 1cnt += 1# 如果 cnt 等于 3,说明需要删除当前字符if cnt == 3:# 将 res 加 1res += 1# 如果 cnt 大于 3,说明当前字符需要删除,# 但是删除后会导致字符串中存在连续三个 'x',# 因此需要将 j 后移一位,即将 j 赋值为 i-1,# 同时将 cnt 减 1,这样可以保证删除当前字符后,# 字符串中不存在连续三个 'x'elif cnt > 3:res += 1cnt -= 1j += 1else:# 如果当前字符不为 'x',将 cnt 置为 0,j 赋值为 icnt = 0j = i# 输出需要删除的字符数量
print(res)
http://www.ds6.com.cn/news/37504.html

相关文章:

  • 找人做网站需要问哪些问题外国黄冈网站推广平台
  • 镇江网站建设一般多少钱杭州网站搜索排名
  • 网站建设项目的实训报告免费发布推广信息网站
  • 网校网站怎么做创建网站花钱吗
  • jquery 炫酷网站长春疫情最新消息
  • 如何在百度做网站付费内容网站
  • 东莞市建设网双桥seo排名优化培训
  • 合肥中科大网站开发腾讯会议价格
  • 用苹果cms做电影网站都需要什么cms
  • 黄页b2b网站大全免费百度公司的发展历程
  • 点广告挣钱网站有哪些东莞关键词排名快速优化
  • 两学一做党员答题网站百度地址
  • 通辽网站建设公司企业的互联网推广
  • 做网站工资多钱深圳网络营销渠道
  • 医院网站建设进度及实施过程郑州网站建设
  • 建网站企业网站的网站建设
  • 快速搭建网站工具seo方案书案例
  • 凡科做的网站怎么改壁纸企业推广是什么职业
  • 宝塔织梦网站建设产品网络营销策划方案
  • 全网营销型网站建设公司宁波好的seo外包公司
  • 申请注册网站域名.商城电商网站分析
  • 胶州做网站公司网络营销分类
  • 在线看免费电影网站海淀区seo引擎优化多少钱
  • 做网站需要买什么设计网站logo
  • 做网站哪家靠谱免费注册二级域名的网站
  • 高端企业网站建设方案上海优化营商环境
  • 做的比较唯美的网站有哪些湖南seo推广多少钱
  • 如何做网站视频模板营销课程培训都有哪些
  • 网站权重6了该则么做优化方案优化网站快速排名软件
  • 女士春深圳 网站制作软文代发价格