蓝桥杯—不同字串(C语言解法)

题目描述

一个字符串的非空子串是指字符串中长度至少为 1 的连续的一段字符组成的串。
例如,字符串aaab 有非空子串a, b, aa, ab, aaa, aab, aaab,一共 7 个。
注意在计算时,只算本质不同的串的个数。
请问,字符串0100110001010001 有多少个不同的非空子串?

答案提交

这是一道结果填空的题,你只需要算出结果后提交即可。
本题的结果为一 个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

思路

  1. 因为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;
}
posted @ 2022-04-01 18:43  两颗不一样的西柚  阅读(340)  评论(0)    收藏  举报