在一个字符串中求从第i个位置开始的len个字符构成的子串。

在一个字符串中求从第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;
}