C/C++函式,比較兩個字元串
設這兩個字元串為str1,str2,
若str1=str2,則返回零;
若str1<str2,則返回負數;
若str1>str2,則返回正數。
matlab中函式,strcmp(s1,s2) 判斷兩個字元串s1和s2是否相同,相同返回true ,不同返回false
基本介紹
- 中文名:strcmp
- 外文名:strcmp
- 類別:庫函式
- 功能:比較字元串s1和s2
- 頭檔案:string.h
- 一般形式:strcmp(字元串1,字元串2)
原型,說明,代碼,源碼,套用舉例1,套用舉例2,使用,
原型
extern int strcmp(const char *s1,const char *s2);
![strcmp strcmp](/img/9/188/nBnauAzYjVzNxgzY2gzNhhzYyQ2M0ITM0YTOwUGNwMTYwcTO0MTM0YWMjZ2LptWa39yYpB3LltWahJ2Lt92YuUHZpFmYuMmczdWbp9yL6MHc0RHa.jpg)
說明
規則
當s1<s2時,返回為負數;
當s1==s2時,返回值= 0;
當s1>s2時,返回正數。
即:兩個字元串自左向右逐個字元相比(按ASCII值大小相比較),直到出現不同的字元或遇'\0'為止。如:
"A"<"B" "a">"A" "computer">"compare"
特別注意:strcmp(const char *s1,const char * s2)這裡面只能比較字元串,即可用於比較兩個字元串常量,或比較數組和字元串常量,不能比較數字等其他形式的參數。
ANSI標準規定,返回值為正數,負數,0 。而確切數值是依賴不同的C實現的。
Return Value
Returns an integral value indicating the relationship between the strings:
return value<0 the first character that does not match has a lower value inptr1than inptr2
return value=0 the contents of both strings are equal
return value>0 the first character that does not match has a greater value inptr1than inptr2
- 當兩個字元串不相等時,C標準沒有規定返回值會是1 或 -1,只規定了正數和負數。有些實現會返回1或-1,但將返回值與1或-1做比較的人,都是不合格的程式設計師。
- 有些會把兩個字元的ASCII碼之差作為比較結果由函式值返回。但無論如何不能以此條依據作為程式中的流程邏輯。
代碼
#include <string.h>#include <memcopy.h>#undef strcmpint strcmp(p1,p2){ const char *p1; const char *p2; register const unsignedchar *s1=(const unsignedchar*)p1; register const unsignedchar *s2=(const unsignedchar*)p2; unsigned reg_charc1,c2; do{ c1=(unsigned char)*s1++; c2=(unsigned char)*s2++; if(c1=='\0') returnc1-c2; }while(c1==c2); return c1-c2;} libc_hidden_builtin_def(strcmp)//最正宗的源碼(他以上代碼是K&R C規範的,ASCI C的在下面)/*strcmp function*/#include <string.h> int(strap)(const char *sl,const char *s2){ /*compare unsigned char sl[],s2[]*/ for(;*sl==*s2;++sl,++s2) if(*sl=='\0') return(0); return((*(unsignedchar*)sl<*(unsignedchar*)s2)?-1:+1);}
strcmp另外的原始碼如下:int __cdecl strcmp(const char *src,const char *dst){ int ret=0; while(!(ret = *(unsigned char *)src - *(unsigned char *)dst) && *dst) ++src,++dst; if(ret<0) ret=-1; else if(ret>0) ret=1; return(ret);}
還有一種模擬算法:int strcmp(const char * src, const char * dst) //字典序比較兩字元串大小{ int ret = 0 ; while(!(ret=*src-*dst)&&*dst) //相等且沒有結束 ++src, ++dst; return( ret );}
源碼
int strcmp(const char *str1,const char *str2){ /*不可用while(*str1++==*str2++)來比較,當不相等時仍會執行一次++, return返回的比較值實際上是下一個字元。應將++放到循環體中進行。*/ while(*str1 == *str2) { assert((str1 != NULL) && (str2 != NULL)); if(*str1 == '\0') return 0; str1++; str2++; } return *str1 - *str2;}
套用舉例1
(在VC6.0中運行通過)
#include <stdio.h>#include <string.h>int main(){ char string[20]; char str[3][20]; int i; for(i=0;i<3;i++) gets(str[i]); if(strcmp(str[0],str[1])>0) strcpy(string,str[0]); else strcpy(string,str[1]); if(strcmp(str[2],string)>0) strcpy(string,str[2]); printf("\nThe largest string is%s\n",string); return 0;}
套用舉例2
(TC中運行通過)
//strcmp.c#include <syslib.h>#include <string.h>intmain(){ char *s1="Hello,Programmers!"; char *s2="Hello,programmers!"; int r; clrscr(); r = strcmp(s1,s2); if(!r) printf("s1 and s2 are identical"); else if(r<0) printf("s1 less than s2"); else printf("s1 greater than s2"); getchar(); return 0;}
使用
strcmp — 二進制安全字元串比較
說明
int strcmp( string $str1 , string $str2 )
注意該比較區分大小寫。
參數
str1第一個字元串。
str2第二個字元串。
返回值
如果 str1小於 str2,返回負數;如果 str1大於 str2,返回正數;二者相等則返回 0。(相等時返回0)
示例:
<?php $var1="Hello"; $var2="Hello"; if(strcmp($var1,$var2)==0) {echo'相等'; } else { echo'不相等'; } ?>
strcasecmp — 二進制安全比較字元串(不區分大小寫)
int strcasecmp(string$str1,string$str2)
- str1
- 第一個字元串。
- str2
- 第二個字元串。
返回值: 如果 str1 小於 str2 返回 < 0; 如果 str1 大於 str2 返回 > 0;如果兩者相等,返回 0。
示例 :
<?php $var1="Hello"; $var2="hello"; if(strcasecmp($var1,$var2)==0){ echo'$var1isequalto$var2inacase-insensitivestringcomparison'; }?>