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)