Подтвердить что ты не робот

Функция strrev() недоступна в Linux?

Я попытался написать код, используя strrev(). Я включил <string.h>, но все равно получаю ссылку strrev ".

Я обнаружил, что strrev() не имеет man-страницы вообще. Зачем?

Поддерживает ли Linux strrev()?

4b9b3361

Ответ 1

Правильный. Используйте одну из доступных альтернативных реализаций:

#include <string.h>

char *strrev(char *str)
{
      char *p1, *p2;

      if (! str || ! *str)
            return str;
      for (p1 = str, p2 = str + strlen(str) - 1; p2 > p1; ++p1, --p2)
      {
            *p1 ^= *p2;
            *p2 ^= *p1;
            *p1 ^= *p2;
      }
      return str;
}

Ответ 2

#include <string.h>

char *strrev(char *str)
{
    if (!str || ! *str)
        return str;

    int i = strlen(str) - 1, j = 0;

    char ch;
    while (i > j)
    {
        ch = str[i];
        str[i] = str[j];
        str[j] = ch;
        i--;
        j++;
    }
    return str;
}

Ответ 3

К сожалению, strrev, по-видимому, отсутствует в glibc string.h.

Очевидно, что я опаздываю на вечеринку здесь-some-code, но мне нравится эта реализация.

#define MAX_CHARS 10000
// safe_usub -- perform safe unsigned subtraction
size_t safe_usub (size_t x, size_t y) {
  return x > y ? x - y : y - x ;
}

char* str_reverse (const char* const str) {
  if (!str) { return NULL; }

  size_t len = strnlen(str, MAX_CHARS);
  char*  new = malloc( sizeof(char) * len );

  size_t i;
  for (i = 0; i < len; i++) {
    new[i] = str[ safe_usub(i + 1, len) ];
  }

  new[i] = 0;

  return new;
}

Ответ 4

Нет строковой библиотечной функции "Для обратной строки"

strrev() отсутствует в компиляторе GCC в Linux или Ubuntu

Ответ 5

Не существует функции библиотеки строк для обращения строки.

strrev() Нет в компиляторе GCC в Linux. Сделайте свою собственную обратную функцию:

reverse.c:

/*
 * C program to reverse a string using recursion
 */
#include <stdio.h>
#include <string.h>

void reverse(char [], int, int);
int main()
{
    char str1[20];
    int size;

    printf("Enter a string to reverse: ");
    scanf("%s", str1);
    size = strlen(str1);
    reverse(str1, 0, size - 1);
    printf("The string after reversing is: %s\n", str1);
    return 0;
}

void reverse(char str1[], int index, int size)
{
    char temp;

    temp = str1[index];
    str1[index] = str1[size - index];
    str1[size - index] = temp;

    if (index == size / 2)
    {
        return;
    }
    reverse(str1, index + 1, size);
}