【C语言】 字符串处理练习(长度统计、出现次数统计、删除、连接、排序)

题目

已知一维字符数组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;
}

结果实现

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值