当前位置:首页 > 教育综合 > 正文

给出一个只包含 G 和 H 的字符串,求有多少个长度大于等于 3 的子串(连续的)

c语言求一个字符串里有几个子串

#include #include int substring(char *str,char *str1);//函数原型 int main(void) { char str[64]={0}; char str1[16]={0}; int i,j,x; printf("please put the string\n"); gets(str);//输入的原字符串 puts(str); printf("\n"); printf("please put the string1 \n"); gets(str1);//输入的字符串中的子串 puts(str1); printf("\n"); i=strle

3.输入一个字符串和 n,输出原串中出现长度大于等于 n 的子串的数目,每个子串出现多次时不可重叠。

您好,这样就可以了

#include
intmain()
{
chars[100];
inti,j,n,count=0;
scanf("%s%d",s,&n);
for(i=0;s[i];i=j)
{
j=i+1;
while(s[j]&&s[i]==s[j])
j++;
if(j-i>=n)
count++;
}
printf("%d\n",count);
}

C语言:写一个函数,求一个字符串的长度.在main函数中输入字符串并输出其长度

#include

using namespace std;

int main()

{

int character(char *a);

char a[20];

int length;

cout<<"请输入一个字符串:"<

cin>>a;

length=character(a);

cout<<"字符串长度为:"<

return 0;

}

扩展资料:

return用法:

在C++的关键字,它提供了终止函数执行的一种方式。当return语句提供了一个值时,这个值就成为函数的返回值.

1、C

在C89中,main()是可以接受的。Brian W.Kernighan和Dennis M.Ritchie的经典巨著The C programming Language 2e(《C程序设计语言第二版》)用的就是main()。不过在最新的C99标准中,只有以下两种定义方式是正确的:

int main(void)

int main(int argc,char*argv[])

当然,我也可以做一点小小的改动。例如:char*argv[]可以写成char**argv;argv和argc可以改成别的变量名(如intval和charval),不过一定要符合变量的命名规则。

如果不需要从命令行中获取参数,请用int main(void);否则请用int main(int argc,char*argv[])。

main函数的返回值类型必须是int,这样返回值才能传递给程序的激活者(如操作系统)。

如果main函数的最后没有写return语句的话,C99规定编译器要自动在生成的目标文件中(如exe文件)加入return 0;,表示程序正常退出。不过,我还是建议你最好在main函数的最后加上return语句,虽然没有这个必要,但这是一个好的习惯。

注意,vc6不会在目标文件中加入return 0;,大概是因为vc6是98年的产品,所以才不支持这个特性。现在明白我为什么建议你最好加上return语句了吧!不过,gcc3.2(Linux下的C编译器)会在生成的目标文件中加入return 0;。

2、C++

C++98中定义了如下两种main函数的定义方式:

int main()

int main(int argc,char*argv[])

int main()等同于C99中的int main(void);int main(int argc,char*argv[])的用法也和C99中定义的一样。同样,main函数的返回值类型也必须是int。

如果main函数的末尾没写return语句,C++98规定编译器要自动在生成的目标文件中加入return 0;。同样,vc6也不支持这个特性,但是g++3.2(Linux下的C++编译器)支持。

参考资料:

百度百科——return

求字符串内最长不重复的子串长度是多少

已知一个字符串,只含有小写字母,求这个字符串的每个字符都不相同的最长子串的长度。 比如: abcd 结果是4 abcab 结果是3 思路: 用一个26个元素的整形数组表示一个字符串中是否含有某个字符。a~b分别映射到数组元素0~25。 用两个指针分别指向字符串的第一个和第二个元素,用第二个指针从左往右扫描字符串。每扫描一个字符,根据数组中对应的值来判断这个字符是否已经出现。 如果没出现,则继续扫描,同时更新已知不相同子串的最大长度。 如果出现过,那么向右移动第一个指针,直到刚才重复的那个字符不再重复,然后继续上面的工作。 源代码: [cpp] view plain copy #include

c语言的一个题

最起码的一点弄错了:C不允许用变量确定数组的大小,scanf("%d",&n); char s[n][80];违反了这一规则。另:C也不允许在任意代码行间声明变量,都得集中在函数开头部位,同样scanf("%d",&n);char s[n][80];因声明语句char s[n][80];在非声明语句scanf("%d",&n);之后而过不了编译。给你写一个做参考:

#include"stdio.h"
#include
#defineN20
intmain(intargv,char*argc[]){
chars[N][80],i,k,n;
printf("Inputn(int0 if(scanf("%d",&n)!=1||n<1||n>N){
printf("Inputerror,exit...\n");
return0;
}
for(k=i=0;i scanf("%80s",s[i]);
if(strcmp(s[i],s[k])<0)
k=i;
}
printf("\nMinis:%s\n",s[k]);
return0;
}

运行样例:

展开全文阅读