千家信息网

C语言是怎样输出唯一的子串

发表于:2025-11-17 作者:千家信息网编辑
千家信息网最后更新 2025年11月17日,C语言是怎样输出唯一的子串,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。题目描述给一个字符串,求长度为m的所有不重复的子串。 比如字
千家信息网最后更新 2025年11月17日C语言是怎样输出唯一的子串

C语言是怎样输出唯一的子串,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

题目描述

给一个字符串,求长度为m的所有不重复的子串。 比如字符串"aaab",我们求长度为2的子串,那么依次为"aa","aa","ab",那么不重复的子串为"aa","ab"

输入

第一行是一个整数K,表示样例的个数。 每个样例的第一行是一个整数m,表示所求子串的长度。 第二行是一个字符串,字符串全部由小写英文字母组成,长度不超过100。

输出

按字典序输出所有不重复子串,每个样例最后输出一个空行。

样例输入

2

2

aaab

3

aaab

样例输出

aa

ab

aaa

这道题可以定义一个二维数组用来存放字符串的所有子串,然后排序,最后一个个输出,遇到相同的只输出一个。

完整代码

#include #include  int main() {    int k,i,j,len,n,l,m;    char str[105]={0},a[102][101]={0},temp[100];    scanf("%d",&k);    while(k--)    {        n = 0;        scanf("%d",&m);        scanf("%s",str);        len = strlen(str);        for(i = 0;i <= len-m;i++)        {            l = 0;            for(j = i;j < i+m;j++,l++)            {                                a[n][l] = str[j];//子串            }            n++;        }        for(i = 0; i < n; i++)//排序        {            for(j = i+1; j < n; j++)            {                if(strcmp(a[i],a[j])>0)                {                    strcpy(temp,a[i]);                    strcpy(a[i],a[j]);                    strcpy(a[j],temp);                }            }        }        for(i = 0;i < n;i++)        {            if(strcmp(a[i],a[i+1])==0)//相同的只输出第一个            continue;            for(j = 0;j < m;j++)            printf("%c",a[i][j]);            printf("\n");        }        printf("\n");          memset(str,'\0',sizeof(str));          memset(a,'\0',sizeof(a));        memset(temp,'\0',sizeof(temp));    }    return 0;}

关于C语言是怎样输出唯一的子串问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注行业资讯频道了解更多相关知识。

0