在一个字符串中求从第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’)。
在一个字符串中求从第i个位置开始的len个字符构成的子串。
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
qfl_sdu 2021-07-09 15:15关注#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; }本回答被题主选为最佳回答 , 对您是否有帮助呢?解决评论 打赏 举报无用 1