编程练习
6.
请编写一个函数,它从一个字符串中提取子字符串。函数的原型应该如下:
int substr(char dst[], char src[], int start, int len);
函数的任务是从src数组起始位置向后偏移start个字符的位置开始,最多复制len个非NUL字符到dst数组。在复制完毕之后,dst数组必须以NUL字符结尾。函数的返回值是存储于dst数组中的字符串的长度。
如果start所指定的位置越过了src数组的尾部,或者start或len的值为负,那么复制到dst数组的是个空字符串。
程序如下:
#include<stdio.h>
#include<string.h>
int substr(char dst[], char src[], int start, int len)
{
int i,length;
length = strlen(src);
if(start >= length || start < 0 || len < 0)
{//若start所指定的字符位置超过了src数组的长度
dst[0] = '\0';//dst数组为空字符串
i = 0;
}
else
{
for(i = 0; i < len; i++)
{
if(start+i < src[len])//若在src中len长度的字符位置大于start所指定位置(逐增)
dst[i] = src[start+i];//则将src中(从start逐渐增加)的字符串赋给dst
else
break;//若循环次数大于等于len长度,则终止整个for循环
}
dst[i] ='\0';//dst数组以NUL结尾
printf("%s:%d",dst,strlen(dst));
}
return strlen(dst);//返回值是dst数组中字符串的长度
}
int main(){
char dst[20],src[20];
int start,len;
scanf("%s%d%d",&src,&start,&len);
substr(dst, src, start, len);
return 0;
}
运行结果:
7.
编写一个函数,从一个字符串中去除多余的空格。函数的原型应该如下:
void deblank(char string[]);
当函数发现字符串中如果有一个地方由一个或者多个连续的空格组成,就把它们改成单个空格字符。注意当你遍历整个字符串时要确保它以NUL字符结尾。
程序如下:
#include<stdio.h>
#include<string.h>
void deblank(char string[])
{
char *i = string;// 清除前数组
char *j = string;// 清除后数组
int flag=0; //记录相邻空格
while (*i!='\0') //输入字符串未结束
{
if(*i==' ') //输入字符串存在空格
{
if(flag>0) //存在相邻空格
{ i++;
continue; //跳出本次循环
}
flag++;
}
else //输入字符串不存在空格
{flag=0;
}
*j++=*i++;
}
*j='\0';
}
int main(){
char str[50];
gets(str);
deblank(str);
puts(str);
}
运行结果:
人生不就是一个起起落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落落的过程。