数据结构-求一个字符串中的某个子串(C语言)

题目描述:

返回顺序串s中从第i(1《i《n)个字符开始的连续j个字符组成的子串。当参数不正确时返回一个空串

代码实例:

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

//定义一个结构体数组
typedef struct {
	char data[6];//字符串12345一共5个数,为什么分配6个空间,原因是c语言中字符串后面自带一个/0多以多分配一个空间
	int length;
}SqString;


//获取子串的函数
SqString SubStr(SqString s, int i, int j) {

	int k = 0;
	SqString str;
	str.length = 0;//定义一个空串,长度为0
	
	//不符合条件返回空串str
	if(i<=0 || i>s.length || j<0 || i+j-1>s.length) {
		return str;	
	}

	//第一个数,它的下标是0,第二个数,它的下标是1,以此类推
	for(k = i-1 ;k<i+j-1;k++) {
		str.data[k-i+1] = s.data[k];
	}
	str.length = j;
	str.data[str.length] = '\0';//如果没有这行代码,就会有乱码的情况出现。字符串都是以\0结尾
	return str;
}


void main() {
	SqString s = {"12345",5};
	s.length = 5;
	s = SubStr(s,1,3);
	printf("%s",s.data);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梁同学与Android

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值