2021-11-03 字符串有效长度、连接以及比较

69 篇文章 3 订阅

1. 求字符串有效长度(2种方法)

第一种:

#include <stdio.h>
#include <assert.h>
int My_strlen(const char *str)
{
	assert(str != NULL);
	if(NULL == str)
	{
         return -1;
	}
	int count = 0;
	while(*str != '\0')
	{
		count++;
		str++;
	}

	//此时 while循环退出  代表着指针str现在指向的是字符串结尾标志'\0'

	return count;
}
int main()
{
	const char *str = "abcdef";
	printf("%d\n", My_strlen(str));
	return 0;
}

运行结果:

第二种:

//用指针-指针的方式  求字符串有效长度
int My_strlen_1(const char *str)
{
	assert(str != NULL);
	if(NULL == str)
    {
        return -1;
    }
	const char *p = str;
	
	while(*p != '\0')
	{
		++p;  //p++都可以
	}

	return p-str;
}
int main()
{
	const char *str = "abcdef";
	printf("%d\n", My_strlen_1(str));
	return 0;
}

运行结果:

2. 字符串连接

#include<stdio.h>
#include<assert.h>
char *My_strcat(char *des, const char *src)
{
	assert(des != NULL && src != NULL);
	if (des == NULL || src == NULL)
	{
		return NULL;
	}

	//让指针p 指向str的结尾标志'\0'
	char *p = des;
	while(*p != '\0')
	{
		p++;
	}

	//从p开始拷贝  拷贝src的值
	while(*p++ = *src++);
	return des;
}
int main()
{
	char str[20] = { "abcde" }; //字符串长度必须给够 
	const char* src = "xyz";
	printf("%s\n", My_strcat(str, src));
	return 0;

}

运行结果:

3. 字符串比较大小

#include<stdio.h>
#include<assert.h>
int My_strcmp(const char *string1, const char *string2)
{
	assert(string1 != NULL && string2!=NULL);
	if(NULL == string1 || NULL == string2)
		return -2;

	while((*string1 == *string2) && (*string1 != '\0'))
	{
		string1++;
		string2++;
	}

	int tmp = *string1 - *string2;
	if(tmp == 0)
	{
		return 0;
	}
	else if(tmp > 0)
	{
		return 1;
	}
	else
	{
		return -1;
	}

}
int main()
{
	const char* string1 = "abcde";
	const char* string2 = "abcdef";
	const char* string3 = "abcde";
	const char* string4 = "abcdw";
	printf("%d\n", My_strcmp(string1, string2));
	printf("%d\n", My_strcmp(string1, string3));
	printf("%d\n", My_strcmp(string1, string4));
	return 0;
}

运行结果:

比较两个字符串前n个值是否相等,如果count过大,那就正常比较

int My_strncmp(const char *string1, const char *string2, int count)
{   
	assert(string1 != NULL && string2!=NULL);
	if(NULL == string1 || NULL == string2)
		return -2;
	//1.两个不相等 2.相等但是是'\0' 3.需要比较的个数count 已经比较完毕
	//如果写成count-- , 则会让循环体代码多执行一次,后置--则表示先用再-1,前置--表示先-1再用
	while(--count &&(*string1 == *string2) && (*string1 != '\0'))
	{
		string1++;
		string2++;
	}

	int tmp = *string1 - *string2;
	if(tmp == 0)
	{
		return 0;
	}
	else if(tmp > 0)
	{
		return 1;
	}
	else
	{
		return -1;
	}

}
int main()
{
	const char* string1 = { " abcde" };
	const char* string2 = { "abcdw" };
	printf("%d\n", My_strncmp(string1, string2,5));
	return 0;
}

运行结果:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值