strcpy дает ошибку сегментации - PullRequest
0 голосов
/ 21 сентября 2019

Ниже приведена рекурсивная функция, которая должна превращать целое число в строку

char* int_to_word(int word_int){
    static char new[2];
    char alphabet[26]={"abcdefghijklmnopqrstuvwxyz"};
    new[0]=alphabet[word_int%27-1];
    //new[1]='\0';
    if(word_int/27==0){
        return new;
    }
    static char *word;
    strcpy(word,strcat(int_to_word(word_int/27),new));
    return word;
}

Я получаю ошибку сегментации со строкой strcpy(word,strcat(int_to_word(word_int/27),new));, когда word_int> 26. На мойзнания, нет причин, по которым это не должно работать.Мое лучшее предположение состоит в том, что мне нужно как-то выделить word перед копированием в него, но изменение инициализатора на static char *word=(*char)malloc(100) не помогло.

1 Ответ

0 голосов
/ 22 сентября 2019

static переменные могут быть использованы.span считает количество символов, необходимое для преобразованного значения.index используется для перебора выделенной памяти, начиная с нуля, используя span - index.
Поскольку letters имеет 26 символов, используйте % 26, чтобы получить значение одного символа, и / 26, чтобы уменьшить исходное значение.для вычисления следующего символа.
12345 будет преобразовано в sgv

#include <stdio.h>
#include <stdlib.h>

char *number_str ( int x);

int main ( void) {
    char *value = NULL;
    if ( ( value = number_str ( 0))) {
        printf ( "%s\n", value);
        free ( value);
    }
    if ( ( value = number_str ( -12345))) {
        printf ( "%s\n", value);
        free ( value);
    }
    if ( ( value = number_str ( 26))) {
        printf ( "%s\n", value);
        free ( value);
    }
    return 0;
}

char *number_str ( int x) {
    char *out = NULL;
    static char const *letters = "abcdefghijklmnopqrstuvwxyz";
    static size_t index = 0;
    static size_t span = 0;
    if ( x == 0) {
        if ( NULL == ( out = malloc ( span + 1 + ( 0 == span)))) {
            fprintf ( stderr, "malloc problem\n");
            return NULL;
        }
        out[span + ( 0 == span)] = 0;//zero terminate
        if ( 0 == span) {
            out[0] = 'a';//when the original value of x is zero
        }
        index = span;
        return out;
    }
    else {
        if ( 0 == span) {
            index = 0;
            if ( x != abs ( x)) {
                span++;//add one for leading '-'
            }
        }
        span++;
        out = number_str ( x / 26);//recursive call
    }
    if ( out) {
        int sign = 0;
        if ( x != abs ( x)) {
            out[0] = '-';//set leading '-'
            sign = 1;
        }

        int digit = x % 26;
        out[span - index + sign] = letters[abs ( digit)];
        index--;//span - index to iterate from 0 to span
        if ( ! span || ( out[0] == '-' && 1 == span)) {
            //the last iteration. reset to zero
            index = 0;
            span = 0;
        }
    }
    return out;
}
...