1. 程式人生 > 其它 >C-(字串)strcmp字串比較的模擬實現

C-(字串)strcmp字串比較的模擬實現

#define _CRT_SECURE_NO_WARNINGS 1

#include<stdio.h>
#include<string.h>
#include<assert.h>
//1.計數器的版本
//2.遞迴的版本
//3.指標-指標
//int print_len(const char* arr)
//{
//    int count = 0; //計數器
//    assert(arr != NULL);
//    while (*arr !='\0')
//    { 
//        count++;
//        arr++;
//    }
//    return count;
//} //char* my_strcat(char* dest,const char* src) //{ // //hello_\0 arr1 // //world\0 arr2 // //1.找到目標字串的\0 // //2.源資料追加過去,包含\0 // char* ret = dest; // assert(dest != NULL); // assert(src != NULL); // while (*dest) // \0的ASSCII碼是0 // { // dest++; // } // //2.源資料追加過去,包含\0 // while (*dest++ = *src++) // { // ;
// } // return ret;//返回目標空間的起始地址 //} //int main() //{ // char arr1[20] = "hello \0########"; // char arr2[] = "world"; // //char* ret = my_strcat(arr1, arr2);//字串追加(連線) // char* ret = strcat(arr1, arr1); // printf("%s\n", ret); // // return 0; //} //int main() //{ // //strcmp-字串比較大小 // int ret = strcmp("abbb", "abc");
//比較對應位置的ASSICC碼值 // printf("%d ", ret); // return 0; //} // int my_strcmp(const char* s1, const char* s2) { assert(s1 && s2); while (*s1 == *s2) { if (*s1 == '\0') { return 0; } s1++; s2++; } if (*s1 > *s2) { return 1; } else { return -1; } } int main() { char* p = "abcdef"; char* q = "abqb"; int ret = my_strcmp(p, q); if (ret > 0) { printf("p > q\n"); } else if (ret < 0) { printf("p < q\n"); } else { printf("p == q\n"); } }