Программа находит символ с наименьшим кодом ascii в строке и выводит его. Моя проблема заключается в сообщении: Ошибка сегментации (сбрасывание ядра). Почему и где это происходит? Спасибо за внимание.Ошибка сегментации (сбрасывание ядра) - как исправить мой код?
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(void) {
char* str = NULL;
int* mincode = NULL;
int* count = NULL;
char* mincodeChar = NULL;
str = (char *) malloc(50 * sizeof(char));
mincode = (int *) malloc(1 * sizeof(int));
count = (int *) malloc(1 * sizeof(int));
if (NULL == str || NULL == mincode || NULL == count){
printf("Alloc error");
return EXIT_FAILURE;
}
fgets(str, 50, stdin);
printf("your string: ");
puts(str);
*mincode = (int)(str[*count]);
*mincodeChar = *(str + *count);
for (*count = 0; str[*count] != '\0'; (*count)++) {
if((int)str[*count] < (*mincode)) {
(*mincode) = (int)str[*count];
mincodeChar = (str + *count);
printf("%c", *mincodeChar);
}
}
printf("your character: ");
printf("%c", *mincodeChar);
free(str);
free(mincode);
free(count);
return EXIT_SUCCESS;
}
Почему вы динамически выделяете память, когда у вас есть фиксированные размеры времени компиляции? В частности, зачем выделять память для * one * 'int'? Почему бы не использовать простую переменную 'int'? –
1) at '* mincode = (int) (str [* count]);': '* count' не инициализирован. – BLUEPIXY
Также см. [Это обсуждение о литье результата 'malloc'] (http://stackoverflow.com/questions/605845/do-i-cast-the-result-of-malloc). –