问题描述
对于一个字符串 S,我们定义 S 的分值 f(S) 为 S 中出现的不同的字符个数。例如 f("aba")=2,f("abc")=3, f("aaa")=1。
现在给定一个字符串 S[0…n−1](长度为 n),请你计算对于所有 S 的非空子串 Si…j,f(S[i…j])的和是多少。
输入格式
输入一行包含一个由小写字母组成的字符串 S。
输出格式
输出一个整数表示答案。
样例输入
ababc
样例输出
28
样例分析
子串 f值
a 1
ab 2
aba 2
abab 2
ababc 3
b 1
ba 2
bab 2
babc 3
a 1
ab 2
abc 3
b 1
bc 2
c 1
评测用例规模与约定
对于 20% 的评测用例,1≤n≤10;
对于 40% 的评测用例,1≤n≤100;
对于 50% 的评测用例,1≤n≤1000;
对于 60% 的评测用例,1≤n≤10000;
对于所有评测用例,1≤n≤100000。
#include<stdio.h>
#include<string>
int main()
{
char s[100000];
int nums[26];
int i,j,k;
int a,sum=0,sum1=0;
gets_s(s);//输入字符串
int len = strlen(s);
for (i = 0; i < len; i++)
{
memset(nums, 0, sizeof(nums));//nums数组清零
a = 0;
sum = 0;
for (j = i; j < len; j++)
{
if (nums[s[j] - 'a'] == 0)
{
nums[s[j] - 'a'] = 1;
a++;
sum = sum + a;
}
else
{
sum =sum+a;
}
}
sum1 = sum1 + sum;
}
printf("%d\n", sum1);
}