1.int strncmp ( char * str1, char * str2, size_t num) 用法:#include <string.h> 功能: 比较字符串str1和str2的前n个字符. 返回结果:如果前n字节完全相等,返回值就=0;在前n字节比较过程中,如果出现str1[n]与str2[n]不等,则返回(str1[n]-str2[n]) #include<stdio.h> #include<assert.h> #include<stdlib.h> int strncmp(const char * str1, const char * str2, size_t num) { assert(str1); assert(str2); //在接下来的while函数中 //第一个循环条件:--num,如果比较到前num个字符则退出循环 //第二个循环条件:*str1 == *str2,如果两字符比较不等则退出循环 while (--num&&*str1 == *str2) { if (*str1== '\0')//*str1,如果str1指向的字符串末尾退出循环 return 1; else str1++;//str1指针自加1,指向下一个字符 str2++;//str2指针自加1,指向下一个字符 } return *str1 - *str2;//返回比较结果 } int main() { char *arr1 = "aaabbb", *arr2 = "aaaccc"; int m = 0; printf("输入要比较的个数:"); scanf("%d", &m); int ret=strncmp(arr1, arr2, m); if (ret == 1) { printf("两个字符串相同!\n"); } else { printf("两个字符串差值为:%d\n", ret); } system("pause"); return 0; } 2.char *strncat(char * s1,const char * s2.size_t n); s2字符串中只有前n个字符被追加到s1字符串,复制过来的s2字符串的第一个字符覆盖了 s1字符串结尾的空字符。s2字符串中包括s2[n]在内的字符都不会被复制,并且追加 一个空字符到所得结果后面。返回值是s1。 #include<stdio.h> #include<assert.h> #include<stdlib.h> char *strncat(char *dest, char const *src,size_t n) { assert(dest); assert(src); char *temp = dest; while (*dest) { dest++; } while (n-- && *src) { *dest++ = *src++; } *dest = '\0'; return temp; } int main() { char arr[50] = "i come from china!!"; char *p = " me too!!"; int m = 0; printf("输入要追加的个数:"); scanf("%d", &m); strncat(arr, p,m); printf("%s\n", arr); system("pause"); return 0; } 3.void *memset(void *s, int ch, size_t n); 函数解释:将s中前n个字节 (typedef unsigned int size_t )用 ch 替换并返回 s 。 memset:作用是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法[1] 。 #include<stdio.h> #include<stdlib.h> #include<assert.h> #include<string.h> void *my_memset(void *s, int ch, size_t n) { assert(s); void *temp = s; while (n--) { *(char *)s= (char)ch; s = (char *)s+1; } return temp; } int main() { char arr[] = "abcdefg"; int m = 0; printf("输入要初始化的内容:"); scanf("%s", &m); my_memset(arr,m,strlen(arr)); puts(arr); system("pause"); return 0; } 4.int memcmp(const void *buf1, const void *buf2, unsigned int count); 比较内存区域buf1和buf2的前count个字节。 该函数是按字节比较的。 #include<stdio.h> #include<stdlib.h> int my_memcmp(const void *s1, const void *s2, size_t n) { char *arr1 = (char *)s1; char *arr2 = (char *)s2; while (--n&&*arr1&&*arr1 == *arr2) { arr1++; arr2++; } return *arr1 - *arr2; } int main() { char *p = "abcdef"; char *q = "abcdef"; int r; r=my_memcmp(p, q, 3); if (r == 0) { printf("两个字符串相等!\n"); } else if (r < 0) { printf("字符串p小于字符串q!\n"); } else printf("字符串p大于字符串q!\n"); system("pause"); return 0; }
用c语言实现strncmp,strncat,memset, memcmp
原创
©著作权归作者所有:来自51CTO博客作者菜鸟笔记的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
C语言模拟实现memset.memcmp函数
C语言模拟实现memset.memcmp函数
C语言.memset.memcmp -
模拟实现C语言strncpy.strncat.strncmp函数
模拟实现C语言strncpy.strncat.strncmp函数
C语言.strncpy.strncar. -
模拟实现strncpy,strncat,strncmp
...
#include 字符串 ios -
memcmp与strncmp函数【转】字符串 字符串比较 javascript html linux