C语言问题,大神请进
编写一个程序,求一字符串的子串,要求求子串的功能用一函数实现,函数原型为“char*substr(char*s,intpos,intlen);”即从s字符串的pos位置起...
编写一个程序,求一字符串的子串,要求求子串的功能用一函数实现,函数原型为“char *substr(char *s,int pos,int len);”即从s字符串的pos位置起,取len个字符组成新的字符串作为函数的返回值,pos的位置从1开始,如substr("1234",2,2)返回的子串是"23"。
展开
2个回答
展开全部
#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;
}
展开全部
#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;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询