Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 29.09.2019
Сообщений: 24
1

Отсортировать одномерный массив по возрастанию

30.10.2019, 12:36. Показов 1187. Ответов 2
Метки си (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте! Задание: отсортировать одномерный массив по возрастанию. Всё вроде бы сделал правильно, но при компиляции (нужно будет на Линуксе с помощью аргументов командной строки запускать программу) вылезает сообщение Segmentation fault. Например, ввожу ./_имя программы_ 10 1 , и появляется сообщение про сегментацию, или же когда аргументов несколько, хотя, по идее, лишние аргументы должны просто "откинуться", и сама программа успешно выполнится. А если ввожу просто название программы, то програма не завершается, пока я не введу несколько значений ( скорее всего, ошибка где-то в циклах, поэтому и требует ввести значения). В общем, что нужно исправить, чтобы программа работала корректно?

Вот и сам код

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <malloc.h>
 
int main (int argc, char **argv)
{
    printf("Задание: Отсортировать одмерный массив по возрастанию.\n");
    puts(" ");
    srand (time (NULL));
    int n, way;
    int *x;
    int i, max;
if (argc > 2)
{
    n = atoi(argv[1]);
    way = atoi(argv[2]);
    if(n!=0 && way!=0) {
    printf("Вы указали следующие данные:\n");
    printf("%d элементов %s способ заполнения массива\n\n", n, way);
    }
} else {
    printf("Вы ввели слишком мало аргументов, или же аргументы неверны!\n");
    printf("Размерность массива должна быть не больше 20.");
    printf("Попробуйте, например, следующий вариант: %s 10 1,\nгде 10 - количество элементов, 1 - ввод элементов вручную, а 2 - автоматическое заполнение.\n", argv[0]); 
    printf("Введите размерность ещё раз: \n");
    scanf("%d", &n);
}
        if(n > 20) {
        puts("Размер массива не должен превышать 20!");
        exit(0);
    } else {
        x = (int*)malloc(n*sizeof(int));
    }
    if(!(way == 1 || way == 2)) {
        printf("Введите 1, если хотите заполнить массив вручную(целыми положительными числами)\nВведите 2, если хотите сгенерировать массив(-30..30): ");
        scanf("%d", &way);
    }
if (way==2)
    {
        for(i=0; i<n; i++) {
        x[i]=-30+rand()%-69;
    }
    } else if (way==1) {
        printf("Введите эллементы массива:\n");
          for(i=0; i<n; i++) {
          printf("Элемент[%d]: ", i);
          scanf("%d", &x[i]);
          }
    } else {
        printf("Вы можете выбрать способ ввода только или вручную (1) или автоматически (2)\n");
        exit(0);
    }
    
    puts(" ");
    printf("Исходные элементы массива: \n");
    for (i=0; i<n; i++);
    {
        printf("%d ", x[i]);
    }
    printf("Порядок после сортировки:\n");
        for(i=0;i<n-1;i++)      
        {
            if(x[i] > x[i+1])
            {
            max=x[i];
            x[i]=x[i+1];
            x[i+1]=max;
            }
            printf("%d ", x[i]);
            
        }
        free(x);
        return 0;
    }
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
30.10.2019, 12:36
Ответы с готовыми решениями:

Разделить массив на два отдельных массива, отсортировать один массив по убыванию, а второй - по возрастанию
Помогите пожалуйста. Дан массив из 20 целых чисел, расположенных в случайном порядке. Половина...

Дан одномерный массив из n чисел. Вывести на экран, отсортирован ли массив по возрастанию
1. Дан одномерный массив из n чисел. Вывести на экран, отсортирован ли массив по возрастанию. 2....

Отсортировать массив по возрастанию
вот код, задача отсортировать массив по возрастанию, а он ,вместо отсортированного массива, выводит...

Отсортировать массив по возрастанию
Задача отсортировать массив по возрастанию массив должен заполнятся рандомно и вручную Нет мыслей

2
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
12456 / 7480 / 1753
Регистрация: 25.07.2009
Сообщений: 13,759
30.10.2019, 13:57 2
Лучший ответ Сообщение было отмечено dupple как решение

Решение

В конкурсе на самое запутанное решение простой задачи Вы явный фаворит!
Первое, что сразу в глаза бросается:
Цитата Сообщение от dupple Посмотреть сообщение
C
1
2
3
way = atoi(argv[2]); 
/*...*/
printf("%d элементов %s способ заполнения массива\n\n", n, way);
%s принимает строку в качестве параметра, а Вы число подсунули.
Наверняка ещё что-нибудь не так, не осилил.
Совет: научитесь использовать отступы при форматировании не как бог на душу положит, а так, чтобы выделять ими логические блоки в программе - жить станет заметно легче!
1
0 / 0 / 0
Регистрация: 29.09.2019
Сообщений: 24
30.10.2019, 16:40  [ТС] 3
В общем, с кодом уже разобрался. Действительно, было много ненужных символов и ошибок. Спасибо всем, кто помог!
0
30.10.2019, 16:40
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
30.10.2019, 16:40
Помогаю со студенческими работами здесь

Отсортировать массив по возрастанию
Добрый день. Условие в теле кода. Не получется запихнуть код в интрукцию for. Замену минимального...

Отсортировать массив чисел по возрастанию
Здравствуйте. Подскажите, почему не работает. #include &lt;stdio.h&gt; #include &lt;string.h&gt; void...

Отсортировать двумерный массив по возрастанию по строкам
нужно отсортировать двумерный массив по возрастанию по строкам где ошибка for(i=0;i&lt;3;i++) {...

Отсортировать массив книг по возрастанию их стоимости
Уважаемые программист, помогите пожалуйста отсортировать книги за ценой по возрастанию их...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru