Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42

Сортировка одномерного массива выбором - в чем ошибка

01.03.2016, 11:04. Показов 935. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет. Пытаюсь написать алгоритм, который будет сортировать одномерный массив заданной длины:
1. находить минимум среди элементов,
2. менять его местами с последним элементом в массиве
3. при каждой следующей итерации программа обрабатывает на один элемент меньше, и так пока массив не будет отсортирован.
Сразу говорю, до функций и классов обучение пока не дошло, пытаюсь реализовать просто циклами и ветвлением. Получилось вот что (см.ниже), не могу понять, где ошибка, почему-то цикл поиска минимума, видимо, не уменьшает количество элементов для поиска с каждой итерацией сортировочного цикла, а каждый раз обрабатывает 13 элементов, т.к. находит снова и снова один и тот же минимум и заполняет им постепенно весь массив. Подскажите, пожалуйста, что не так.
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
#include "stdafx.h"
#include <iostream>
using namespace std;
 
 
int main()
{
    setlocale(LC_ALL, "Russian");
 
    
    int array[13] = { 5, 8, 32, 6, 15, 1, 4, 29, 17, 99, 3, 56, 51 };
 
    int n;
    int temp = 0;           
    int number = 0;
    int Min = array[0];
 
    
 
    for (n = 12; n >= 1; n--) // задаем цикл сортировки, с каждой итерацией меняется n - номер последнего элемента в массиве 
 
    {
            for (i = 0; i <= n; i++)  // задаем цикл нахождения минимума в массиве, перебирает элементы с нулевого по n-ный,
//с каждой итерацией цикла сортировки должен перебирать на один элемент меньше 
            
            {
                if (Min > array[i])
                {
                    Min = array[i];
                    number = i;
                }
            }
        
 
            temp = array[n];  // сортировка
            array[n] = Min;
            array[number] = temp;
 
 
            for (i = 0; i <= 12; i++)  // цикл вывода массива на печать после каждой итерации сортировки
            {
                cout << array[i] << ' ';
            }
        }
    
 
 
getchar();
getchar();
return 0;
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.03.2016, 11:04
Ответы с готовыми решениями:

Сортировка одномерного массива. В чем ошибка?
Такая вот ошибка: ОС Windows инициировала точку останова в МояПрограмма.exe. Это может быть вызвано повреждением кучи и указывает на...

В чем ошибка? Ссртировка выбором и сортировка вставкой
108-ая строка. error C2372: a: переопределение; различные типы косвенного обращения 110-ая строка. error C2440: =: невозможно...

Сортировка одномерного массива, где ошибка в задаче?
Делал Сортировку одномерного массива... по этому примеру: for j:= 1 to N-1 do for i:= 1 to N-j do if N&gt;N then ...

2
62 / 62 / 55
Регистрация: 18.10.2014
Сообщений: 190
01.03.2016, 11:19
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
#include <iostream>
using namespace std;
int main()
{
    setlocale(LC_ALL, "Russian");
 
    
    int array[13] = { 5, 8, 32, 6, 15, 1, 4, 29, 17, 99, 3, 56, 51 };
 
    int n;
    int temp = 0;           
    int number = 0;
  
    int i;
    for (n = 12; n >=1; n--) 
    {
        int Min = array[0];
        number =0;
            for ( i = 1; i <= n; i++)  
            {
                if (Min > array[i])
                {
                    Min = array[i];
                    number = i;
                }
            }
            temp = array[n];
            array[n] = Min;
            array[number] = temp;
            for ( i = 0; i <= 12; i++)
            {
                cout << array[i] << ' ';
            }
            cout<<endl;
        }
getchar();
getchar();
return 0;
}
1
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
01.03.2016, 11:23  [ТС]
Спасибо большое!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.03.2016, 11:23
Помогаю со студенческими работами здесь

Сортировка массива - в чем ошибка?
Попытался написать код сортировки массива. Алгоритм такой: ищем самое маленькое число в массиве и помещаем в первый элемент массива, а...

В чем ошибка?? (сортировка массива структур)
Проблема с сортировкой и выводом. Кто может помогите, и объясните:-[ где ошибка :umnik:

Осуществление сортировки выбором одномерного массива
private void button1_Click(object sender, EventArgs e) { int j; string s = textBox1.Text; int l =...

Сортировка одномерного массива и ошибка "error C2065: _ необъявленный идентификатор"
Препод дал пример кода по сортировке одномерного массива, я его набрал в MV c++ 2010, и мне выдаёт вот такое. #include...

с сортировкой выбором! в чем ошибка?
я создал базу данных с консоли и проблема в том что он сортирует только года а остальное он оставляет как есть не меняя его позицию до ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru