C Language Comparsion: strcmp (), strncmp (), strcasecmp (), strncasecmp ()


Ejemplo

Las strcase* strcase no son estándar C, sino una extensión POSIX.

La función strcmp compara lexicográficamente dos matrices de caracteres terminadas en nulo. Las funciones devuelven un valor negativo si el primer argumento aparece antes del segundo en orden lexicográfico, cero si se comparan igual o positivo si el primer argumento aparece después del segundo en orden lexicográfico.

#include <stdio.h>
#include <string.h>

void compare(char const *lhs, char const *rhs)
{
    int result = strcmp(lhs, rhs); // compute comparison once
    if (result < 0) {
        printf("%s comes before %s\n", lhs, rhs);
    } else if (result == 0) {
        printf("%s equals %s\n", lhs, rhs);
    } else { // last case: result > 0
        printf("%s comes after %s\n", lhs, rhs);
    }
}

int main(void)
{
    compare("BBB", "BBB");
    compare("BBB", "CCCCC");
    compare("BBB", "AAAAAA");
    return 0;
}

Salidas:

BBB equals BBB
BBB comes before CCCCC
BBB comes after AAAAAA

Como función strcmp , la función strcasecmp también compara lexicográficamente sus argumentos después de traducir cada carácter a su correspondiente en minúscula:

#include <stdio.h>
#include <string.h>

void compare(char const *lhs, char const *rhs)
{
    int result = strcasecmp(lhs, rhs); // compute case-insensitive comparison once
    if (result < 0) {
        printf("%s comes before %s\n", lhs, rhs);
    } else if (result == 0) {
        printf("%s equals %s\n", lhs, rhs);
    } else { // last case: result > 0
        printf("%s comes after %s\n", lhs, rhs);
    }
}

int main(void)
{
    compare("BBB", "bBB");
    compare("BBB", "ccCCC");
    compare("BBB", "aaaaaa");
    return 0;
}

Salidas:

BBB equals bBB
BBB comes before ccCCC
BBB comes after aaaaaa

strncmp y strncasecmp comparan como máximo n caracteres:

#include <stdio.h>
#include <string.h>

void compare(char const *lhs, char const *rhs, int n)
{
    int result = strncmp(lhs, rhs, n); // compute comparison once
    if (result < 0) {
        printf("%s comes before %s\n", lhs, rhs);
    } else if (result == 0) {
        printf("%s equals %s\n", lhs, rhs);
    } else { // last case: result > 0
        printf("%s comes after %s\n", lhs, rhs);
    }
}

int main(void)
{
    compare("BBB", "Bb", 1);
    compare("BBB", "Bb", 2);
    compare("BBB", "Bb", 3);
    return 0;
}

Salidas:

BBB equals Bb
BBB comes before Bb
BBB comes before Bb