How to compare strings in c language
Comparison method: 1. bcmp(), compares the first n bytes of a string to see if they are equal; 2. strcmp(), compares strings case-sensitively; 3. strcmp(), not size-sensitive Written comparison string; 4. strncmp() or strnicmp(), case-sensitive comparison of the first n characters of the string.
The operating environment of this tutorial: windows7 system, c99 version, Dell G3 computer.
Use bcmp()--Compare the first n bytes of memory (string) to see if they are equal
The prototype is:
int bcmp(const void *s1, const void * s2, int n);
[Parameters] s1, s2 are the two pieces of memory (or two strings) that need to be compared, and n is the length to be compared.
[Return value] If the first n bytes of s1 and s2 are equal or n is equal to 0, then return 0, otherwise return a non-0 value.
bcmp() function does not check for NULL.
In fact, bcmp() and memcmp() have the same function, used to compare whether the first n bytes of the memory block are equal, but the two parameters s1 and s2 are pointers, and strangely located in string. h file, it can also be used to compare strings.
Example:
#include <stdio.h> #include <string.h> int main () { char *s1 = "Golden Global View"; char *s2 = "Golden Global View"; if( !bcmp(s1, s2, 7) ) printf("s1 equal to s2 in first 7 bytes"); else printf("s1 not equal to s2 in first 7 bytes"); return 0; }
Use strcmp()--Compare strings (case sensitive)
The prototype is:
int strcmp(const char *s1, const char *s2);
[Parameters] s1, s2 are the two strings that need to be compared.
The comparison of string sizes is determined by the order in the ASCII code table, and this order is also the value of the characters. strcmp() first subtracts the first character value of s1 from the first character value of s2. If the difference is 0, it will continue to compare the next character. If the difference is not 0, the difference will be returned. For example, comparing the strings "Ac" and "ba" will return the difference (-33) between the characters "A" (65) and 'b' (98).
[Return value] If the strings of parameters s1 and s2 are the same, 0 will be returned. If s1 is greater than s2, a value greater than 0 is returned. If s1 is less than s2, a value less than 0 is returned.
Note: strcmp() performs comparisons in binary and does not consider multi-byte or wide-byte characters.
Example:
#include <string.h> main(){ char *a = "aBcDeF"; char *b = "AbCdEf"; char *c = "aacdef"; char *d = "aBcDeF"; printf("strcmp(a, b) : %d\n", strcmp(a, b)); printf("strcmp(a, c) : %d\n", strcmp(a, c)); printf("strcmp(a, d) : %d\n", strcmp(a, d)); }
Output:
strcmp(a, b) : 32 strcmp(a, c) :-31 strcmp(a, d) : 0
Use strictmp()--Compare strings (case-insensitive)
The prototype is:
int strcmp(char *s1, char *s2);
[Parameter description] s1, s2 are the two strings that need to be compared.
The comparison of string sizes is determined by the order in the ASCII code table, and this order is also the value of the characters. strictmp() first subtracts the first character value of s1 from the first character value of s2. If the difference is 0, it will continue to compare the next character. If the difference is not 0, the difference will be returned. For example, comparing the strings "Ac" and "ba" will return the difference (-33) between the characters "A" (65) and 'b' (98).
[Return value] If the strings of parameters s1 and s2 are the same, 0 will be returned. If s1 is greater than s2, a value greater than 0 is returned. If s1 is less than s2, a value less than 0 is returned.
Note: strictmp() is unique to Windows. The function with the same function under Linux is strcasecmp(), which is included in the header file strings.h.
Another function that compares strings without case sensitivity is strcmpi(). strcmpi() is the macro definition of strictmp(), but this function is not actually provided.
Example: Compare the size of two strings.
#include<stdio.h> #include<string.h> int main(void) { /*定义两个字符串*/ char* s1 = "http://see.xidian.edu.cn/cpp/u/biaozhunku/"; char* s2 = "http://see.xidian.edu.cn/cpp/shujujiegou/"; /*比较字符串(不分大小写)*/ int result = stricmp(s1,s2); // 也可以改成strcmpi() if(result>0) { printf("Result: s1 > s2"); } else if(result<0) { printf("Result: s1 < s2"); } else if(result == 0) { printf("Result: s1 = s2"); } getchar();/*等待用户输入个字符,然后退出*/ return 0; }
Output:
Result: s1 > s2
Use strncmp()--Compare the first n characters of the string (case sensitive)
Its prototype is:
int strncmp ( const char * str1, const char * str2, size_t n );
[Parameters] str1, str2 are the two strings that need to be compared, and n is the number of characters to be compared.
The comparison of string sizes is determined by the order in the ASCII code table, and this order is also the value of the characters. strncmp() first subtracts the first character value of s2 from the first character value of s1. If the difference is 0, then it will continue to compare the next character until the character end mark '\0'. If the difference is not 0, then Return the difference. For example, comparing the strings "Ac" and "ba" will return the difference (-33) between the characters "A" (65) and 'b' (98).
Note: The characters to be compared include the string end mark '\0', and once it encounters '\0', the comparison will end, no matter what n is, the following characters will not continue to be compared.
[Return value] If the first n characters of str1 and str2 are the same, return 0; if s1 is greater than s2, return a value greater than 0; if s1 is less than s2, return a value less than 0.
Note: If the two characters are different, GCC returns the difference between the ASCII codes corresponding to the characters, and VC returns -1 or 1. But what is embarrassing is that strnicmp(), strcmp(), and strictmp() all return -1 or 1 under GCC and VC, not the ASCII difference.
Example: Compare two sets of strings.
#include<stdio.h> #include<string.h> int main(void){ char* s1 = "http://see.xidian.edu.cn/cpp/u/xitong/"; char* s2 = "HTTP://see.xidian.edu.cn/cpp/u/xitong/"; char* s3 = "abc"; char* s4 = "abcxyz"; char* s5 = "123456"; char* s6 = "123"; printf("s1-s2=%d\n", strncmp(s1, s2, 20)); // 是否区分大小写 printf("s3-s4=%d\n", strncmp(s3, s4, 100)); // s3的长度小于s4 printf("s5-s6=%d\n", strncmp(s5, s6, 100)); // s5的长度大于s6 return 0; }
Running results under VC6.0:
s1-s2=1 s3-s4=-1 s5-s6=1
Running results under GCC:
s1-s2=32 s3-s4=-120 s5-s6=52
Use strnicmp()--Compare the first n characters of the string (Case-sensitive)
The prototype is:
int strnicmp ( const char * str1, const char * str2, size_t n );
[Parameters] str1, str2 are the two strings that need to be compared, and n is the number of characters to be compared.
[Return value] If the first n characters of str1 and str2 are the same, return 0; if s1 is greater than s2, return a value greater than 0; if s1 is less than s2, return a value less than 0.
The difference from strncmp() is that if the two characters are different, both GCC and VC return -1 or 1 instead of returning the corresponding ASCII difference.
For other instructions about strnicmp(), please see strncmp(). This is only an example and will not be repeated.
另外一个不区分大小写比较字符串前n个字符的函数是strncmpi(),strncmpi()是strnicmp()的宏定义,实际未提供此函数。
示例:对6组字符串进行比较。
#include<stdio.h> #include<string.h> int main(void){ char* s1 = "http://see.xidian.edu.cn/cpp/u/xitong/"; char* s2 = "HTTP://see.xidian.edu.cn/cpp/u/xitong/"; char* s3 = "abc"; char* s4 = "abcxyz"; char* s5 = "123456"; char* s6 = "123"; printf("s1-s2=%d\n", strnicmp(s1, s2, 20)); // 是否区分大小写 printf("s3-s4=%d\n", strnicmp(s3, s4, 100)); // s3的长度小于s4 printf("s5-s6=%d\n", strnicmp(s5, s6, 100)); // s5的长度大于s6 return 0; }
VC6.0下运行结果:
s1-s2=0 s3-s4=-1 s5-s6=1
GCC下运行结果:
s1-s2=0 s3-s4=-1 s5-s6=1
相关推荐:《C语言视频教程》
The above is the detailed content of How to compare strings in c language. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

C language data structure: The data representation of the tree and graph is a hierarchical data structure consisting of nodes. Each node contains a data element and a pointer to its child nodes. The binary tree is a special type of tree. Each node has at most two child nodes. The data represents structTreeNode{intdata;structTreeNode*left;structTreeNode*right;}; Operation creates a tree traversal tree (predecision, in-order, and later order) search tree insertion node deletes node graph is a collection of data structures, where elements are vertices, and they can be connected together through edges with right or unrighted data representing neighbors.

The truth about file operation problems: file opening failed: insufficient permissions, wrong paths, and file occupied. Data writing failed: the buffer is full, the file is not writable, and the disk space is insufficient. Other FAQs: slow file traversal, incorrect text file encoding, and binary file reading errors.

Algorithms are the set of instructions to solve problems, and their execution speed and memory usage vary. In programming, many algorithms are based on data search and sorting. This article will introduce several data retrieval and sorting algorithms. Linear search assumes that there is an array [20,500,10,5,100,1,50] and needs to find the number 50. The linear search algorithm checks each element in the array one by one until the target value is found or the complete array is traversed. The algorithm flowchart is as follows: The pseudo-code for linear search is as follows: Check each element: If the target value is found: Return true Return false C language implementation: #include#includeintmain(void){i

C language multithreading programming guide: Creating threads: Use the pthread_create() function to specify thread ID, properties, and thread functions. Thread synchronization: Prevent data competition through mutexes, semaphores, and conditional variables. Practical case: Use multi-threading to calculate the Fibonacci number, assign tasks to multiple threads and synchronize the results. Troubleshooting: Solve problems such as program crashes, thread stop responses, and performance bottlenecks.

How to output a countdown in C? Answer: Use loop statements. Steps: 1. Define the variable n and store the countdown number to output; 2. Use the while loop to continuously print n until n is less than 1; 3. In the loop body, print out the value of n; 4. At the end of the loop, subtract n by 1 to output the next smaller reciprocal.

The readdir function in the Debian system is a system call used to read directory contents and is often used in C programming. This article will explain how to integrate readdir with other tools to enhance its functionality. Method 1: Combining C language program and pipeline First, write a C program to call the readdir function and output the result: #include#include#include#includeintmain(intargc,char*argv[]){DIR*dir;structdirent*entry;if(argc!=2){

C language functions are reusable code blocks, receive parameters for processing, and return results. It is similar to the Swiss Army Knife, powerful and requires careful use. Functions include elements such as defining formats, parameters, return values, and function bodies. Advanced usage includes function pointers, recursive functions, and callback functions. Common errors are type mismatch and forgetting to declare prototypes. Debugging skills include printing variables and using a debugger. Performance optimization uses inline functions. Function design should follow the principle of single responsibility. Proficiency in C language functions can significantly improve programming efficiency and code quality.

C language functions include definitions, calls and declarations. Function definition specifies function name, parameters and return type, function body implements functions; function calls execute functions and provide parameters; function declarations inform the compiler of function type. Value pass is used for parameter pass, pay attention to the return type, maintain a consistent code style, and handle errors in functions. Mastering this knowledge can help write elegant, robust C code.
