zoukankan      html  css  js  c++  java
  • strcmp函数

    函数原型:extern int strcmp(char *str1,char * str2)

    参数说明:str1为第一个要比较的字符串,str2为第二个要比较的字符串。
            
    所在库名:#include <string.h>
      
    函数功能:比较字符串str1和str2。
      
    返回说明:返回整数值:当str1<str2时,返回值<0; 当str1=str2时,返回值=0; 当str1>str2时,返回值>0。这种比较是按照字符的字典序进行比较。

    其它说明:暂时无。

    实例:

    第一种情形:

    #include <string.h>
    #include 
    <stdio.h>
    int main()
    {
        
    char *str1="mm";  //str1的字典序比str2的更大(m在b后面)
        char *str2="bbmmzzz"
        
    int inttemp;

        inttemp
    =strcmp(str1,str2);   //将字符串比较的返回值保存在int型变量inttemp中
        if(inttemp<0)
        
    {
            printf(
    "lexicographic(str1) < lexicographic(str2) ");
        }

        
    else if(inttemp>0)
            
    {
                printf(
    "lexicographic(str1) > lexicographic(str2) ");
            }

            
    else
            
    {
                printf(
    "lexicographic(str1) == lexicographic(str2) ");
            }

        
    return 0;
    }

    在VC++ 6.0 编译运行:

    这时字符串比较结果返回值为>0,即str1大于str2。

    第二种情形:

    #include <string.h>
    #include 
    <stdio.h>
    int main()
    {
        
    char *str1="mmbb";
        
    char *str2="bbmm";   //str1与str2的ASCII码一样大,但是str1的字典序比str2的更大(m在b后面)
        int inttemp;

        inttemp
    =strcmp(str1,str2);   //将字符串比较的返回值保存在int型变量inttemp中
        if(inttemp<0)
        
    {
            printf(
    "lexicographic(str1) < lexicographic(str2) ");
        }

        
    else if(inttemp>0)
            
    {
                printf(
    "lexicographic(str1) > lexicographic(str2) ");
            }

            
    else
            
    {
                printf(
    "lexicographic(str1) == lexicographic(str2) ");
            }

        
    return 0;
    }

    在VC++ 6.0 编译运行:

    结果与第一种情形一样,这个要特别注意,比较的不是字符串的ASCII码的大小。

    第三章情形:

     

    #include <string.h>
    #include 
    <stdio.h>
    int main()
    {
        
    char *str1="sky2098";
        
    char *str2="sky2098";   //str1与str2不但ASCII码一样大,而且对应位置字符完全相同,则str1的字典序的大小与str2的相等
        int inttemp;

        inttemp
    =strcmp(str1,str2);   //将字符串比较的返回值保存在int型变量inttemp中
        if(inttemp<0)
        
    {
            printf(
    "lexicographic(str1) < lexicographic(str2) ");
        }

        
    else if(inttemp>0)
            
    {
                printf(
    "lexicographic(str1) > lexicographic(str2) ");
            }

            
    else
            
    {
                printf(
    "lexicographic(str1) == lexicographic(str2) ");
            }

        
    return 0;
    }

    在VC++ 6.0编译运行:

  • 相关阅读:
    Eclipse插件大全 (下)
    Eclipse插件大全 (上)
    Struts2学习笔记
    DisplayTag应用指南
    JFreeChart 2
    JFreeChart 1
    一对一直播app源码开发,多媒体消息发送优化方案
    仿比心视频聊天源码开发,网络节点数量和时延的关系
    一对一直播源码开发,保证实时性要从降低延迟下手
    小视频app源码凭什么成功出圈,守“江山”有多难?
  • 原文地址:https://www.cnblogs.com/lgh1992314/p/5835375.html
Copyright © 2011-2022 走看看