题目
已知一维字符数组s1,s2,s3,s1和s2的内容如下:
s1="a123b345c4m935689dsdfm93rmnwm93e4kr";
s2="m93";
要求:(1)求s1、s2有效字符的长度;(2)统计s2在s1中出现的次数;(3)将s1中与s2相同的字符串删除,并将删除后的结果放入s3中;(4)将s2接在s3后;(5)对s1数组内的字符进行排序,结果还是放入s1中。
逐步分析
(1)有效字符的长度,使用到strlen()函数,注意在主函数前添加<string.h>头文件。
(2)将s2中的字符与s1中的进行比较,如果连续三个字符相等,则计为出现一次。
int i,j,sum=0;
for(i=0;i<strlen(s1);i++)
{
if((s1[i]==s2[0])&&(s1[i+1]==s2[1])&&(s1[i+2]==s2[2]))
{
sum++; //计算重复次数
//printf("重复内容%c%c%c\n",s1[i],s1[i+1],s1[i+2]);
s1[i]==0;
s1[i+1]==0;
s1[i+2]==0;
}
}
printf("s1中重复了s2共%d次\n",sum);
关键部分 :删除字符串中的子串
(3)从s1中删除s2运用strstr()函数,作用是返回一个指针,指向s1第一次出现s2的地方。首先判断s1中已经包含s2,即strstr(s1,s2)不为空(NULL),则进行下面的循环。用*p表示变量的值,当*p未结束时,进行循环赋值。因为指针是指向地址,所以用在s1中的s2后的字符覆盖s2以此对*p赋值。循环删除s1中包含的所有s2。将s1处理后的结果放入s3中,用到strcpy()函数,将s1中的值拷贝到s3中。
char *p;
while(strstr(s1,s2)!=NULL)
{
p=strstr(s1,s2);
while(*p!='\0')
{
*p=*(p+strlen(s2));
p++;
}
}
char s3[50];
strcpy(s3,s1);
//printf("删除后的s3=%s\n",s3);
(4)将s2接在s3后,用到strcat()函数。
(5)对字符串中的字符进行排序。采用选择排序法,外层是比较轮次,内层是依次比较,如果后一个数小于前一个数,则调换位置,要注意将先前的数储存在中间值t里,因为数在赋值过程中会变化。
int c,d,n;
char t;
n=strlen(s1);
for(c=0;c<n-1;c++)
for(d=c+1;d<n;d++)
{
if(s1[d]<s1[c])
{
t=s1[c];
s1[c]=s1[d];
s1[d]=t ;
}
}
printf("排序后的s1=%s",s1);
整体代码
#include <stdio.h>
#include <string.h>
int main()
{
char s1[]="a123b345c4m935689dsdfm93rmnwm93e4kr",s2[]="m93";
printf("s1的有效长度为%d\n",strlen(s1)); //统计s1、s2的有效字符长度
printf("s2的有效长度为%d\n",strlen(s2));
int i,j,sum=0;
for(i=0;i<strlen(s1);i++)
{
if((s1[i]==s2[0])&&(s1[i+1]==s2[1])&&(s1[i+2]==s2[2]))
{
sum++; //计算重复次数 //printf("重复内容%c%c%c\n",s1[i],s1[i+1],s1[i+2]);
s1[i]==0;
s1[i+1]==0;
s1[i+2]==0;
}
}
printf("s1中重复了s2共%d次\n",sum);
char *p; //删除字符串中的子串
while(strstr(s1,s2)!=NULL)
{
p=strstr(s1,s2);
while(*p!='\0')
{
*p=*(p+strlen(s2));
p++;
}
}
//printf("s1=%s\n",s1);
char s3[50]; //将s1中的值拷贝到s3中
strcpy(s3,s1);
printf("删除后的s3=%s\n",s3);
strcat(s2,s3); //将s3接在s2后
printf("连接后的s2=%s\n",s2);
int c,d,n; //s1排序
char t;
n=strlen(s1);
for(c=0;c<n-1;c++)
{
for(d=c+1;d<n;d++)
{
if(s1[d]<s1[c])
{
t=s1[c];
s1[c]=s1[d];
s1[d]=t ;
}
}
}
printf("排序后的s1=%s",s1);
return 0;
}
结果实现