题目描述
编一返回指针值的函数,求字符串的子串。
输入
先输入一个整数n,表示有n个测试数据,对于每个测试数据:
1)先按提示“input string:”输入字符串
2)然后按提示“i=”输入求子串的起始位置i
3)再按提示“j=”输入子串长度j
输入举例(粗体字的表示从键盘输入)
2
input string:I am a student
i=6
j=5
input string:ab
i=3
j=2
输出举例:
a stu
Error
提示
注意在每次gets之前,要用getchar();读掉前面输入的已在键盘缓冲区中的回车符。
#include <stdio.h>
char *substr(char *s,int i,int j)
{
int n,t;
static char sub[100];
char *q=sub;
for(n=0;s[n]!='\0';n++);
if(i>0&&i<=n-j+1&&j>0&&j<=n-i+1) /*判断i和j的值是否正确*/
{
for(t=0;t<j;t++)
q[t]=s[i+t-1];
q[t]='\0';
return(q); /*返回子串首地址*/
}
else return(NULL); /*返回空指针(0值)*/
}
int main()
{
int i,j,n;
char a[100];
char *p;
scanf("%d",&n);
for(;n>0;n--)
{
printf("input string:");
getchar(); /*回车符会被当做输入的字符串,所以需要缓冲回车符*/
gets(a);
printf("i="); scanf("%d",&i);
printf("j="); scanf("%d",&j);
p=substr(a,i,j);
if(p)
printf("%s\n",p);
else
printf("Error\n");
}
return 0;
}