蓝桥杯—不同字串(C语言解法)
题目描述
一个字符串的非空子串是指字符串中长度至少为 1 的连续的一段字符组成的串。
例如,字符串aaab 有非空子串a, b, aa, ab, aaa, aab, aaab,一共 7 个。
注意在计算时,只算本质不同的串的个数。
请问,字符串0100110001010001 有多少个不同的非空子串?
答案提交
这是一道结果填空的题,你只需要算出结果后提交即可。
本题的结果为一 个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。
思路
- 因为C语言中处理字符串太麻烦了,所以可以将输入转化为整数,然后存入数组,判重也更容易了
代码
#include<stdio.h>
int res;
int main(){
int i,len,flag,sum=0;
char s[20];
int num1[20];
long long int num2[200];
for(i=0;;i++){
scanf("%c",&s[i]);
if(s[i]=='\n')break;
//num1[i]=s[i]-96;//示例,转化为整数
if(s[i]=='0')num1[i]=9;//0 1转换为数字,任意都可
else num1[i]=8;
}
len=i;
for(i=0;i<len;i++){
sum=0;//记录从i开始到j结束的和,方便判重
for(int j=i;j<len;j++){//遍历输入的数据数组,i表示开始,j表示结束
flag=1;
sum=sum*10+num1[j];//直接加会漏掉,aa 和 b 都是2会漏
for(int k=0;k<res;k++){//存储结果的数组
if(sum==num2[k]){
flag=0;
break;
}
}if(flag){num2[res++]=sum;}
}
}
printf("%d",res);
return 0;
}