首尾字符相同的子字符串的数目

2023-12-27 04:38

本文主要是介绍首尾字符相同的子字符串的数目,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

直接上栗子:

假如输入字符是:

"abcab"

那么输出结果为:

7

解释:该字符串所有的子字符串列出来,你会发现,首尾字符相同的子字符串有:

"a"
"abca"
"b"
"bcab"
"c"
"a"
"b"

一共七个,所以输出7。

再举个栗子:

输入字符串:

cab

输出:

3

解释,首尾字符相同的子字符串有:

"c"
"a"
"b"

栗子已经很很清楚了,其实题目也比较简单,那么首先想到的肯定是把所有的子字符串全部搞出来,然后判断一下首尾字符是否相同,就可以了。

这个想法当然可行,但是时间复杂度较高,属于 O(n2) 级别的,所以还得想办法。

从第二个栗子我们已经可以看出,其实输出结果还是跟字符串本身的长度是有关系的,这是因为把字符串中任意一个字符单独拿出来就是符合题意的子字符串,当然,结果一般比字符串长度要大。

那么我们可以这么想了,假如一个字符串中有一种字符它出现了n次:

"....a......a......a.......a......."

那么以相同的字符所在位置截取的字符串肯定是符合题意的,那么这样的字符串又有多少种呢,答案很显然: C2n 种,也就是n个中任意挑选两个,发现这个规律以后,那么代码就很好写了,当然要计算组合个数,首先要对字符进行统计:

#include <bits/stdc++.h>
using namespace std;
const int MAX_CHAR = 26;int countSubstringWithEqualEnds(string s)
{int result = 0;int n = s.length();int count[MAX_CHAR] = {0};for (int i=0; i<n; i++)count[s[i]-'a']++;for (int i=0; i<MAX_CHAR; i++)result += (count[i]*(count[i]+1)/2);return result;
}int main()
{string s("abcab");cout << countSubstringWithEqualEnds(s);return 0;
}

这个时间复杂度就是 O(n) 级别的了。

这篇关于首尾字符相同的子字符串的数目的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/541903

相关文章

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

C#中字符串分割的多种方式

《C#中字符串分割的多种方式》在C#编程语言中,字符串处理是日常开发中不可或缺的一部分,字符串分割是处理文本数据时常用的操作,它允许我们将一个长字符串分解成多个子字符串,本文给大家介绍了C#中字符串分... 目录1. 使用 string.Split2. 使用正则表达式 (Regex.Split)3. 使用

Java中JSON字符串反序列化(动态泛型)

《Java中JSON字符串反序列化(动态泛型)》文章讨论了在定时任务中使用反射调用目标对象时处理动态参数的问题,通过将方法参数存储为JSON字符串并进行反序列化,可以实现动态调用,然而,这种方式容易导... 需求:定时任务扫描,反射调用目标对象,但是,方法的传参不是固定的。方案一:将方法参数存成jsON字

hdu1496(用hash思想统计数目)

作为一个刚学hash的孩子,感觉这道题目很不错,灵活的运用的数组的下标。 解题步骤:如果用常规方法解,那么时间复杂度为O(n^4),肯定会超时,然后参考了网上的解题方法,将等式分成两个部分,a*x1^2+b*x2^2和c*x3^2+d*x4^2, 各自作为数组的下标,如果两部分相加为0,则满足等式; 代码如下: #include<iostream>#include<algorithm

spoj705( 求不相同的子串个数)

题意:求串s的不同子串的个数 解题思路:任何子串都是某个后缀的前缀,对n个后缀排序,求某个后缀的前缀的个数,减去height[i](第i个后缀与第i-1 个后缀有相同的height[i]个前缀)。 代码如下: #include<iostream>#include<algorithm>#include<stdio.h>#include<math.h>#include<cstrin

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

string字符会调用new分配堆内存吗

gcc的string默认大小是32个字节,字符串小于等于15直接保存在栈上,超过之后才会使用new分配。

如何将一个文件里不包含某个字符的行输出到另一个文件?

第一种: grep -v 'string' filename > newfilenamegrep -v 'string' filename >> newfilename 第二种: sed -n '/string/!'p filename > newfilenamesed -n '/string/!'p filename >> newfilename

C和指针:字符串

字符串、字符和字节 字符串基础 字符串就是一串零个或多个字符,并且以一个位模式为全0的NUL字节结尾。 字符串长度就是字符串中字符数。 size_t strlen( char const *string ); string为指针常量(const修饰string),指向的string是常量不能修改。size_t是无符号数,定义在stddef.h。 #include <stddef.h>

PHP字符串全排列

方法一: $str = 'abc';$a =str_split($str);perm($a, 0, count($a)-1);function perm(&$ar, $k, $m) {if($k == $m){ echo join('',$ar), PHP_EOL;}else {for($i=$k; $i<=$m; $i++) {swap($ar[$k], $ar[$i]);perm($ar