在一个字符串中求从第i个位置开始的len个字符构成的子串。
问题描述:
在一个字符串中求从第i个位置开始的len个字符构成的子串。i和len都从0开始记。
(1)函数原型可设计为: void subString(char *src, int i, int len, char sub)。src为源串首地址,sub为子串首地址
(2)首先要考虑i的值和len的值是否合法:若i<0或i>=strlen(src),则i不合法,无法截取子串;若len<0或i+len>=strlen(src),则len的值不合法,也无法截取子串
(3)指针p1初始为src+i,指针p2初始为sub,用一个循环(循环次数为len次),将源串从i位置开始的字符一个个赋值给sub串中(p2++=*p1++)。循环退出后,在sub串的末尾添加 ‘\0’(*p2=’\0’)。
答
#include <stdio.h>
#include <string.h>
void subString(char *src, int i, int len, char* sub)
{
char* p1;
char* p2;
if(i<0 || len >= strlen(src)|| i+len >= strlen(src))
return;
p1 = src+i;
p2 = sub;
while(len>0)
{
*p2++ = *p1++;
len--;
}
*p2 = '\0';
}
int main()
{
char buf[100]={0};
char sub[50]={0};
gets(buf);
subString(buf,4,10,sub);
printf("%s\n",sub);
return 0;
}