strcmp,strncmp函数详解

2024-04-29 23:12
文章标签 函数 详解 strcmp strncmp

本文主要是介绍strcmp,strncmp函数详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

字典序

字典序,也称为词典序或字序,是指对于两个字符串而言,逐个比较对应位置的字符,字符大小是按照ASCII码从小到大来比较的,如果字符串相同部分的前缀都相同,则较短的词有较小的字典序;如果比较的字符串长度不同,那么较短的字符串在前。

举例来说,在字典序中,字符串 "apple" 会排在 "banana" 之前,因为第一个不同的字符是 'a' 和 'b',而 'a' 在ASCII码中比 'b' 小。同样地,"apple" 会排在 "app" 之后,因为虽然 "app" 是 "apple" 的前缀,但 "apple" 长度更长。

字典序在多种场合中都有应用,特别是在编程和数据结构中,比如排序算法、字典树(Trie)等。在这些应用中,字典序提供了一种明确的顺序,使得我们可以对字符串进行排序、查找或其他操作。

 strcmp函数

strcmp函数是C语言中的一个字符串比较函数,用于比较两个字符串是否相等

注意这是根据两个字符串相同位置的字符对应的ASCII码值进行大小的比较,并不是比较字符串长度,也就是说这个结果取决于两个字符串中第一个不同字符的ASCII码的大小

函数原型为:

int strcmp(const char *s1, const char *s2);

函数参数:

  • s1:要比较的第一个字符串
  • s2:要比较的第二个字符串

函数返回值:

  • 如果s1和s2相同,则返回0
  • 如果s1小于s2,则返回一个负数
  • 如果s1大于s2,则返回一个正数

函数功能:

  • 比较两个字符串,并返回比较结果

函数实例:

#include <stdio.h>
#include <string.h>int main() {char str1[10] = "Hello";char str2[10] = "HellO";int result;result = strcmp(str1, str2);if(result == 0) {printf("两个字符串相等\n");} else {printf("两个字符串不相等\n");}return 0;
}

输出结果:

 两个字符串不相等

注意点

1,字符串的比较是按照字典序进行的,因此大小写字母的比较结果不同。

#include <stdio.h>
#include <string.h>int main()
{char str1[] = "hello";char str2[] = "HELLO";int ret = strcmp(str1, str2);if (ret == 0)printf("str1和str2相等\n");else if (ret > 0)printf("str1大于str2\n");elseprintf("str1小于str2\n");return 0;
}


 运行结果: 

str1大于str2

2,在比较字符串时,需要确保字符串以'\0'结尾,否则可能会导致比较结果不正确。

#include <stdio.h>
#include <string.h>int main()
{char str1[] = "hello";char str2[] = "hello";str1[5] = '!';int ret = strcmp(str1, str2);if (ret == 0)printf("str1和str2相等\n");else if (ret > 0)printf("str1大于str2\n");elseprintf("str1小于str2\n");return 0;
}

 运行结果: 

str1大于str2

分析: 

在这段代码中,我们将str1字符串的结尾标识符'\0'改成了'!',运行代码后,输出结果为"str1大于str2"。这是因为str1字符串没有以'\0'结尾,所以strcmp函数会继续比较下去,直到遇到str2字符串的结尾标识符'\0'。由于str1字符串比str2字符串长,所以str1被认为是大于str2。

模拟实现

strcmp函数是C语言标准库中的一个函数,用于比较两个字符串。它的基本功能是逐个比较两个字符串中的字符,直到找到一个不同的字符或者遇到字符串的结束符\0。基于这个定义,strcmp函数的模拟实现可以有多种方式。以下是一些可能的模拟实现方式:

1. 基本循环比较

这是最直接的模拟实现方式,使用循环逐个比较两个字符串中的字符。

 #include <stddef.h> // 包含 size_t 的定义  int my_strcmp_basic(const char *s1, const char *s2) { assert(s1&&s2); while (*s1 && (*s1 == *s2)) {  s1++;  s2++;  }  return *(const unsigned char *)s1 - *(const unsigned char *)s2;  } 

2. 指针算术实现

使用指针算术可以稍微简化代码,使循环内部的索引操作更加清晰。

int my_strcmp_pointer(const char *s1, const char *s2) {assert(s1&&s2);   while (*s1 && (*s1 == *s2)) {  s1++;  s2++;  }  return *(const unsigned char *)s1 - *(const unsigned char *)s2;  
}

3. 使用宏定义简化比较操作

可以定义一些宏来简化比较操作,但这通常不会改变算法的基本结构。

 #define COMPARE_CHARS(c1, c2) ((c1) - (c2))  int my_strcmp_macro(const char *s1, const char *s2) { 
assert(s1&&s2);  while (*s1 && (*s1 == *s2)) {  s1++;  s2++;  }  return COMPARE_CHARS(*s1, *s2);  } 

注意事项:

  1. 在所有实现中,我们都将字符转换为unsigned char类型,以避免在有符号字符为负时发生符号扩展问题。这是为了确保比较操作按预期进行。
  2. strcmp函数在比较字符串时区分大小写,这意味着大写和小写字母被视为不同的字符。如果你需要不区分大小写的比较,你需要实现一个不同的函数,比如strcasecmp或stricmp,并在比较之前将字符转换为相同的大小写。
  3. 在实际应用中,还需要考虑错误处理,比如当s1或s2为NULL时应该怎么做。标准库函数strcmp在任一参数为NULL时会返回未定义的结果,因此模拟实现时也应遵循相同的约定或提供额外的错误检查。
     

 strncmp函数

  1. strncmp函数是标准C库(C Standard Library)中的一个用于比较字符串的函数。
  2. 与strcmp函数类似,strncmp函数也用于比较两个C风格字符串(以空字符’\0’结尾的字符数组),但它只比较前n个字符。
  3. strncmp函数的原型定义在<string.h>头文件中。

它的原型如下:

int strncmp(const char *str1, const char *str2, size_t n);

其中,str1和str2分别是待比较的两个字符串的指针,n是指定要比较的字符数。

如果str1和str2的前n个字符相等(或者在比较过程中遇到了空字符’\0’),则strncmp返回0。
如果str1在字典顺序上小于str2(即str1的第一个不同字符的ASCII值小于str2的对应字符),则strncmp返回一个负整数。

如果str1在字典顺序上大于str2(即str1的第一个不同字符的ASCII值大于str2的对应字符),则strncmp返回一个正整数。

需要注意的是,比较的结果是根据字符的ASCII码值来确定的。如果n大于两个字符串中较短的字符串的长度,函数会一直比较到较短的字符串的末尾。

示例代码如下:

#include <stdio.h>
#include <string.h>int main() {char str1[] = "Hello";char str2[] = "World";int result = strncmp(str1, str2, 3);if (result < 0) {printf("str1 is less than str2\n");} else if (result > 0) {printf("str1 is greater than str2\n");} else {printf("str1 is equal to str2\n");}return 0;
}

这段代码比较了str1和str2的前3个字符,结果为"str1 is less than str2",因为'H'的ASCII码值为72,'W'的ASCII码值为87

strncmp和strcmp的区别

srcmp 和 strncmp 都是 C 语言的字符串比较函数,用于比较两个字符串的大小。它们的区别在于参数和返回值的处理方式。

  1. strcmp 函数:

    • 参数:strcmp 函数接受两个参数,分别是要比较的两个字符串。
    • 返回值:strcmp 函数的返回值为整型,比较结果为负数、零、正数三种情况,分别表示第一个字符串小于、等于、大于第二个字符串。
  2. strncmp 函数:

    • 参数:strncmp 函数除了接受两个字符串参数外,还额外接受一个整型参数 n,用于指定要比较的字符个数。
    • 返回值:strncmp 函数的返回值也为整型,比较结果与 strcmp 函数类似,表示第一个字符串小于、等于、大于第二个字符串。

不同之处:

  • strcmp 函数会比较两个字符串的每个字符,直到遇到不相等的字符或者一个字符串的结束符 '\0'。而 strncmp 函数会在指定的字符个数内进行比较,如果没有达到指定字符个数,就会根据比较结果返回。
  • strncmp 函数可以用于比较部分字符串,而 strcmp 函数只能比较整个字符串。

需要注意的是,在使用 strcmp 或 strncmp 函数比较字符串时,需要保证字符串以 '\0' 结尾,否则可能导致比较结果不正确。

这篇关于strcmp,strncmp函数详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/947410

相关文章

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Redis中Stream详解及应用小结

《Redis中Stream详解及应用小结》RedisStreams是Redis5.0引入的新功能,提供了一种类似于传统消息队列的机制,但具有更高的灵活性和可扩展性,本文给大家介绍Redis中Strea... 目录1. Redis Stream 概述2. Redis Stream 的基本操作2.1. XADD

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串