C语言:求子串

题目描述

编一返回指针值的函数,求字符串的子串。

输入
先输入一个整数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;
}

猜你喜欢

转载自blog.csdn.net/weixin_43540427/article/details/85007523
今日推荐