从字符串中提取一个字符串

C语言,从字符串中提取一个字符串,int substr(char dst[], char src[],int start,int len)

目标是:从src数组的起始位置开始向后偏移start个字符的位置开始, 最多复制len个非NUL字符到dst数组中,在复制完毕之后,dst 必须以NUL结尾,函数的返回值是存储于dst 数组的字符串的长度

方法一:

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include<assert.h>
int strlen(char * string)
{
	int length;
	for(length=0;*string++!='\0';)
		length+=1;
	return length;
}

int substr(char dst[], char src[],int start,int len)
{
    char* sc = src+start;
    int n = strlen(sc);
    int i = 0;
	int **ret=NULL;
	assert(dst != NULL );
	assert(src != NULL ); 
    if(n < len)
    {
        len = n;
    }
    while(len)
    {
        dst[i] = sc[i];
        len--;
        i++;
    }
    dst[i] = '\0';
}
int main()
{
	char string[]="hello-my-college";
	char string1[100]={0};
	int ret=0;
	int num=0;
	int count=0;
	printf("please the len and the num is:\n");
	scanf("%d%d",&num,&count);
	ret=substr(string1,string,num,count);
	printf( "目的数组长度 : %d \n",count);  
    printf( "目的数组为: %s \n",string1);  
	system("pause");
	return 0;
}

方法二:

#define _CRT_SECURE_NO_WARNINGS 
#include <stdio.h>
#include <stdlib.h>
#include<assert.h>
#include<math.h>
int strlen(char * string)
{
	int length;
	for(length=0;*string++!='\0';)
		length+=1;
	return length;
}

int substr( char dst[], char src[], int start, int len )  
{  
    char *temp = dst;
    int dst_len = 0;  
    int src_len = strlen(src); 
	int i=0;  
	assert( dst != NULL && src != NULL ); 
    if( start<0 || len<=0 || src_len < start )  
        printf( "提取位置或字符个数不符合要求 !\n" ); 
    for( i=0; i<start; i++ )  
         src++;  
    while( dst_len < len && (*temp++ = *src++) != '\0' )   // 若把比较长度放在后面,就会多复制一个字符  
        dst_len++;  
    *temp = '\0';  
    return dst_len;  
}  
int main()
{
	char string[]="hello-my-college";
	char string1[100]={0};
	int ret=0;
	int num=0;
	int count=0;
	printf("please the len and the num is:\n");
	scanf("%d%d",&num,&count);
	ret=substr(string1,string,num,count);
	printf( "目的数组长度 : %d \n",count);  
       printf( "目的数组为: %s \n",string1);  
	system("pause");
	return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Ashley zhao

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

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

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

打赏作者

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

抵扣说明:

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

余额充值