给出一个只包含 G 和 H 的字符串,求有多少个长度大于等于 3 的子串(连续的)
- 教育综合
- 2023-06-29 07:57:09
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=strle3.输入一个字符串和 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 最起码的一点弄错了:C不允许用变量确定数组的大小,scanf("%d",&n); char s[n][80];违反了这一规则。另:C也不允许在任意代码行间声明变量,都得集中在函数开头部位,同样scanf("%d",&n);char s[n][80];因声明语句char s[n][80];在非声明语句scanf("%d",&n);之后而过不了编译。给你写一个做参考: 运行样例:扩展资料:
求字符串内最长不重复的子串长度是多少
已知一个字符串,只含有小写字母,求这个字符串的每个字符都不相同的最长子串的长度。 比如: abcd 结果是4 abcab 结果是3 思路: 用一个26个元素的整形数组表示一个字符串中是否含有某个字符。a~b分别映射到数组元素0~25。 用两个指针分别指向字符串的第一个和第二个元素,用第二个指针从左往右扫描字符串。每扫描一个字符,根据数组中对应的值来判断这个字符是否已经出现。 如果没出现,则继续扫描,同时更新已知不相同子串的最大长度。 如果出现过,那么向右移动第一个指针,直到刚才重复的那个字符不再重复,然后继续上面的工作。 源代码: [cpp] view plain copy #includec语言的一个题
#include"stdio.h"
#include
#defineN20
intmain(intargv,char*argc[]){
chars[N][80],i,k,n;
printf("Inputn(int0
printf("Inputerror,exit...\n");
return0;
}
for(k=i=0;i
if(strcmp(s[i],s[k])<0)
k=i;
}
printf("\nMinis:%s\n",s[k]);
return0;
}
下一篇
返回列表