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

    原型:int strcmp(const char *str1,const char *str2)

    原理:根据大于,小于,相等分别返回正,负,零

    实现:

    int strcmp(const char* str1, const char* str2)  
    {  
        int ret = 0;  
        while(!(ret=*str1-*str2) && *str1)  
        {  
            str1++;  
            str2++  
        }  
      
      
        if (ret < 0)  
        {  
            return -1;  
        }  
        else if (ret > 0)  
        {  
            return 1;  
        }  
        return 0;  
    }  

    方法2:

    int strcmp(const char* str1, const char* str2)  
    {  
        while ((*str1) && (*str1 == *str2))  
        {  
            str1++;  
            str2++;  
        }  
      
      
        if (*str1 > *str2)  
        {  
            return 1;  
        }  
        else if (*str1 < *str2)  
        {  
            return -1;  
        }  
        else  
        {  
            return 0;  
        }    
    }  

    错误的代码:"abcd"和“abfd”会显示相等,为什么?:

    int strcmp(const char *str1,const char *str2)  
    {  
        while ((*str1) && (*str1++ == *str2++)) 
        {  
        NULL;  
        }  
      
      
        if (*str1 > *str2)  
        {  
            return 1;  
        }  
        else if (*str1 < *str2)  
        {  
            return -1;  
        }  
        else  
        {  
            return 0;  
        }   
    }  
  • 相关阅读:
    bzoj 3226 [Sdoi2008]校门外的区间(线段树)
    bzoj 1513 [POI2006]Tet-Tetris 3D(二维线段树)
    cf293E Close Vertices(树分治+BIT)
    点分治练习:不虚就是要AK
    点分治练习: boatherds
    bzoj 4016 [FJOI2014]最短路径树问题(最短路径树+树分治)
    bzoj 1876 [SDOI2009]SuperGCD(高精度+更相减损)
    464 整数排序Ⅱ
    445 余弦相似度
    488 快乐数
  • 原文地址:https://www.cnblogs.com/litifeng/p/7465173.html
Copyright © 2011-2022 走看看