C语言问题,大神请进

编写一个程序,求一字符串的子串,要求求子串的功能用一函数实现,函数原型为“char *substr(char *s,int pos,int len);”即从s字符串的pos位置起,取len个字符组成新的字符串作为函数的返回值,pos的位置从1开始,如substr("1234",2,2)返回的子串是"23"。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char* substr(char* s, int pos, int len)
{
char* t=(char*)malloc(sizeof(char)*(len+1));
int str_len=strlen(s);
if(pos<=0 || pos>str_len || (pos+len-1)>str_len || len<1)
{
return "Error!";
}
int i=pos-1,j=0;
for(j;j<len;j++)
{
t[j]=s[i++];
}
t[j]='\0';
return t;
}

int main()
{
printf("\nsubstr(\"Microsoft\",5,3)=%s",substr("Microsoft",5,3));
printf("\nsubstr(\"Microsoft\",2,15)=%s",substr("Microsoft",2,15));
return 0;
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2018-06-04
#include <stdio.h>
#include <stdlib.h>
char *substr(char *s,int pos,int len)
{
     char *result;
     int i;
     pos--;
     s=s+pos;
     result=malloc(sizeof(char)*(len+1));
     for(i=0;i<len&&*s!='\0';i++)
     {
          *result++=*s++
          pos++;
      }
      *result='\0';
      return result;
}

相似回答