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

Сортировка элементов в массиве по убыванию

22.05.2018, 16:34. Показов 971. Ответов 2

Author24 — интернет-сервис помощи студентам
День добрый! Получил очередное задание, но не могу реализовать его в виду нехватки знаний.

Необходимо написать функцию void*minSort(int**a,*int*n),, которая сортирует элементы массива по убыванию, т.е. а[0] наибольшее значение a[n-1] наименьшее.

1. Находит минимальный элемент в массиве а , сохраняя его значение и индекс.
2. Меняет местами минимальный элемент с последним. Используя другую функцию swap (int *a, int *b).
3. Поиск необходимо начинать с начала массива , но не затрагивать уже отсортированную часть этого массива. Последний найденный элемент, считается отсортированным и не принимает участие в дальнейшей сортировке.
4. Функция должна останавливаться, если в не отсортированной части массива не осталось больше элементов.


Вот , что у меня вышло. Но сортировка проходит наоборот, не так как мне надо. Может у кого есть идеи, как реализовать данную функцию?

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
void minSort ();
 
int main()
{
    int b;
 
 
    printf("Geben Sie N:");
    scanf("%i", &b);
 
    int a[b];
 
    srand(time(NULL));
 
    for (int i = 0; i < b; i++)
    {
        a[i] =rand() %100;
    }
 
 
    minSort(a, b);
 
    for (int i = 0; i<b; i++)
        printf("%d = %i \n", a[i], i);
 
    return 0;
}
 
void swap (int * a, int * b)
{
 
    if (a == NULL || b == NULL)
        return;
 
    int tmp = *a;
    *a = *b;
    *b = tmp;
 
    return;
}
 
 
 
void minSort (int* a, int n)
{
    int min;
    int *o;
    int *p;
    for (int i = 0; i < n-1 ; ++i)
    {
        min = i;
 
        for (int j = i + 1; j < n; ++j)
        {
            if (a[j] < a[min])
                min = j;
        }
        o=&a[i];
        p=&a[min];
 
        swap(o,p);
        {
 
        }
    }
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
22.05.2018, 16:34
Ответы с готовыми решениями:

Сортировка четных элементов массива по возрастанию, а нечетных-по убыванию
Задача в общем такая: Дан целочисленный массив.Отсортировать его четные элементы по возрастанию, а...

Дана матрица M*N. Сортировка положительных элементов по убыванию, остальных - по возрастанию. Нули в конце
Добрый вечер! Дан массив M*N. Необходимо отсортировать ее по строкам так, чтобы вначале шли все...

Сортировка элементов в двумерном массиве
есть массив int mas; нужно сорт. строк так чтобы первые элементы колонки были расположены в...

Сортировка строк по убыванию сумм элементов строк
Я рандомно задал массив M x N: #include &lt;stdio.h&gt; #include &lt;time.h&gt; #include &lt;conio.h&gt; #define...

2
2489 / 1147 / 707
Регистрация: 25.04.2016
Сообщений: 3,294
23.05.2018, 13:30 2
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
// размер массива:
#define N 10
 
void minSort(int *, int);   // алгоритм сортировки по убыванию
void swap(int *, int *);    // меняет два числа местами
 
int main (void)
{
    srand(time(NULL));      // новая точка отсчета рнд
    int a[N], i;
    // заполним массив случайными:
    for (i=0; i<N; i++)
        a[i] = rand() %N;
 
    // выведем массив на экран:
    for (i=0; i<N; i++)
        printf("%2d", a[i]);
    printf("\n\n");
 
    // отсортируем по убыванию:
    minSort(a, N);
 
    // снова выведем на экран:
    for (i=0; i<N; i++)
        printf("%2d", a[i]);
    printf("\n");
 
    // конец программы
    return 0;
}
// ------------------------------------------------------------
void minSort(int * a, int n)
{
    int i, k, m;
    for (k=n-1; k>-1; k--)
    {
        m = 0;                          // примем, что первый элемент массива и есть минимальное число
        for (i=k; i>-1; --i)            // тепеь найдем индекс по-настоящему наименьшего элемента
            if (a[i] < a[m]) m = i;     // если элемент массива i меньше минимального, значит он и есть минимальный
        if (a[k] != a[m])               // после этого цикла нам нужно поменять первый c конца элемент массива и найденный минимальный местами
            swap(&a[k], &a[m]);         // однако если элементы равны, то и менять нет смысла
    }
}
// ------------------------------------------------------------
void swap(int * a, int * b)
{
    int t = *a;
    *a = *b;
    *b = t;
}
0
0 / 0 / 2
Регистрация: 24.04.2018
Сообщений: 61
24.05.2018, 15:04  [ТС] 3
Спасибо за вашу помощ. Но цикл ищет с конца, у меня в задании стоит, что поиск необходимо начинать каждый раз с начала массива. То есть цикл пробегается с начала в конец, в последующем с начала и до отсортированой части, не затрагивая ее.
0
24.05.2018, 15:04
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.05.2018, 15:04
Помогаю со студенческими работами здесь

Сортировка по убыванию в одномерном массиве
Сформировать одномерный массив действительными случайными числами в диапазоне (K, L), N=12....

Сортировка главной диагонали по убыванию в двумерном массиве
Приветствую. Нужно отсортировать главную диагональ по убыванию. Сколько тем уже пересмотрел,...

Сортировка элементов не по убыванию
Дано натуральное N (1&lt;=N&lt;=10), целочисленный квадратный массив-матрица (aij), 0&lt;= i ,j &lt;N....

Сортировка массива по убыванию элементов
Скажите пожалуйста, что не так, если не так, в этом коде) Задание: отсортировать массив по...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Алгоритмика
hw_wired 28.01.2025
Введение: Основы алгоритмики и её роль в информатике В современном мире программирование и алгоритмическое мышление стали неотъемлемой частью образования и профессиональной деятельности. . . .
Информационное моделирование
hw_wired 28.01.2025
Введение в информационное моделирование В современном мире информационное моделирование стало неотъемлемой частью научной, образовательной и профессиональной деятельности. Это мощный инструмент. . .
Объекты и их имена
hw_wired 28.01.2025
Введение: Основы объектного подхода и их роль в информатике В современном мире информационных технологий объектный подход стал фундаментальным принципом организации и обработки информации. Этот. . .
Элементы алгоритмизации
hw_wired 28.01.2025
Основы алгоритмизации В современном мире алгоритмы играют фундаментальную роль в развитии информационных технологий и программирования. Понимание основ алгоритмизации является ключевым элементом в. . .
Человек и информация
hw_wired 28.01.2025
Введение: роль информации в познании мира В современном мире информация играет фундаментальную роль в процессе познания окружающей действительности. Она представляет собой совокупность сведений об. . .
Компьютер и информация
hw_wired 28.01.2025
Эволюция вычислительных машин История развития вычислительной техники начинается задолго до появления первых электронных устройств. Человечество всегда стремилось упростить процесс вычислений и. . .
Информационные технологии
hw_wired 28.01.2025
Введение в современные технологии работы с информацией В современном мире информационные технологии стали неотъемлемой частью практически всех сфер человеческой деятельности. Они существенно. . .
Информация вокруг нас
hw_wired 28.01.2025
Основные понятия информации В современном мире понятие информации является фундаментальным и охватывает практически все сферы человеческой деятельности. Информация представляет собой совокупность. . .
Компьютер для начинающих
hw_wired 28.01.2025
Введение в мир компьютерных технологий В современном мире информация стала одним из важнейших ресурсов человечества, определяющим развитие общества и технологий. Наша жизнь неразрывно связана с. . .
[golang] 189. Rotate Array
alhaos 28.01.2025
Повороты рукоятки, целочисленный слайс нужно сдвинуть на целое положительное число. Мне очень нравится решение на GO / / https:/ / leetcode. com/ studyplan/ top-interview-150/ package topInterview . . .
КуМир: решение задач на матрицы
bytestream 28.01.2025
КуМир представляет собой среду для обучения программированию, которая включает в себя мощные инструменты для работы с матрицами. Матрица в программировании - это двумерный массив, состоящий из. . .
КуМир: решение задач на строки
bytestream 28.01.2025
В системе программирования КуМир работа со строковыми данными является одним из важнейших аспектов создания программ. Строки представляют собой последовательности символов, заключенные в кавычки,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru