Мне нужно создать программу, которая сортирует одно слово в алфавитном порядке и должна быть выполнена с использованием массивов и указателей.
Я попытался удалить размер массива и выделить память, но это дало мне ту же ошибку сегментации. Я не знаю, связана ли проблема с передачей массива в функцию или сортировку по пузырькам. Я добавил оператор печати в функцию, поэтому я предполагаю, что я правильно передаю массив. Когда блин введен, он печатает внутри функции. Я больше склоняюсь к пузырьковой сортировке, вызывающей проблему, потому что я могу устранить ее, и это избавит от ошибки сегментации.
void main(void)
{
int num;
double swap1 = 18.4 , swap2 = 95.73;
char theString[50];
char beginning, ending;
printf("Enter a number:\n");
scanf("%d", &num);
doubleme(&num);
printf("%d is the value you entered doubled.\n", num);
printf("Before swapping value a is %lf and value b is %lf\n", swap1, swap2);
swap(&swap1, &swap2);
printf("After swapping value a is %lf and value b is %lf\n", swap1, swap2);
printf("Enter a word and I will tell you the first and last character of the alphabet within it.\n");
scanf("%s", theString);
firstLast(theString, &beginning, &ending);
printf("%s is the first character and %s is the last.\n", beginning, ending);
}
void doubleme(int *x)
{
*x = 2 * *x;
}
void swap(double *a, double *b)
{
double temp;
temp = *a;
*a = *b;
*b = temp;
}
void firstLast(char theString[], char *first, char *last)
{
int i, j, n;
n = strlen(theString);
char temp;
printf("%c\n", theString[4]);
for(i = 0; i < (n - 1); i++)
{
for(j = 0; j < (n - 1); j++)
{
if(theString[j] > theString[(j+1)])
{
temp = theString[j];
theString[j] = theString[(j+1)];
theString[(j+1)] = temp;
}
}
}
*first = theString[0];
*last = theString[(n-1)];
}
Мне нужна функция для сортировки любой введенной строки и возврата значений в основную строку с использованием массивов и указателей.