解题思路:
这题如果暴力遍历(O(n*n)),超时是肯定的
由于必须遍历数组,所以只能在O(n)的基础上做一些操作
思路:
遍历‘a’-‘z’,找出s中每一个字母能做的最大贡献,换句话说就是单看一个字母能存在于多少个字符串中 并且能计数
由于忽略重复性,对于单个字母的贡献可以从上一个字母的下标一直到字符串尾
s = input() c = 'a' ans = 0 while ord(c)<=ord('z'): if c in s: li = [-1] for i in range(len(s)): if c==s[i]: li.append(i) li.append(len(s)) for i in range(1, len(li)): ans += (li[i]-li[i-1])*(li[-1]-li[i]) c = chr(ord(c)+1) print(ans)
注意事项:
参考代码:
0.0分
6 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复