小乐乐与字符串

152 阅读1分钟
描述
在庆祝祖国母亲70华诞之际,老师给小乐乐出了一个问题。大家都知道China的英文缩写是CHN,那么给你一个字符串s,你需要做的是统计s中子串“CHN”的个数。
子串的定义:存在任意下标a < b < c,那么“s[a]s[b]s[c]”就构成s的一个子串。如“ABC”的子串有“A”、“B”、“C”、“AB”、“AC”、“BC”、“ABC”。


输入描述:
输入只包含大写字母的字符串s。(1 ≤ length ≤ 8000)
输出描述:
输出一个整数,为字符串s中字串“CHN”的数量。

image.png

# 以H为中心
def get_num(string,start,end,c):
    r=0;
    for i in string[start:end]:
        if i==c:
            r=r+1;
    return r;

s=input()
res=0
for i in range(len(s)):
    if s[i]=='H':
        couC=get_num(s, 0, i, 'C')
        couN=get_num(s,i+1,len(s),'N')
        res=res+couC*couN
print(res)