8.2oppo提前批笔试

文章讨论了如何使用Python解决两个问题:一是统计给定字符串中长度为k的连续子串,其中所有字母出现次数为偶数的个数;二是寻找长度为K的数组子串,其中至少有一个元素出现次数大于等于子串大小一半的“好数组”个数。
摘要由CSDN通过智能技术生成

1.1 连续字符串字符出现偶数次

题目描述:

一个长度为N的字符串,小欧想知道有多少个长度为k的连续子串满足所有字母出现次数为偶数次。
输入描述
第一行输入两个正整数字符串总长度N,连续子串长度k
第二行输入字符串
输出描述
一个整数,代表满定条件的子串的个数
例:
5 2
aabbc
输出:2
5 2
aaaaa
输出:4

解题思路

对于每个长度为k的子串,我们可以统计其中每个字母出现的次数,然后判断所有字母的出现次数是否都为偶数。
如果是,则这个子串满足条件,计数器加1。

python 代码

n, k = map(int, input().split())
s = input().strip()

count = 0
for i in range(n-k+1):
    sub = s[i:i+k]
    freq = [0]*26
    for c in sub:
        freq[ord(c)-ord('a')] += 1
    if all(f % 2 == 0 for f in freq):
        count += 1
print(count)

1.2 树,森林

没写,题目不记得了

1.3 好数组

题目描述

“好数组”定义为当且仅当存在某元素的出现次数不小于数组大小的一半。现在有一个长度为N的数组,想要知道其长度
为K的子串的好数组的个数。
输入描述
第一行输入两个正整数字符串总长度N,连续子串长度k
第二行输入字符串
输出描述
一个整数,代表满定条件的子串的个数

python 解题

from collections import Counter
n,k=map(int, input().split())
arr = list(map(int,input().split()))
count=0
for i in range(n-k+1):
    sub=arr[i:i+k]
    counter=Counter(sub)
    max_count=max(counter.values())
    if max_count>=(k+1)//2:
        count+=1
print(count)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值