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

Как правильно вывести каждую итерацию цикла сортировки выбором

15.10.2017, 13:10. Показов 3016. Ответов 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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#include<iostream>
#include<conio.h>
#include<cstdlib>
#include<ctime>
using namespace std;
void vvod_klav(int *a, int n) //функция ввода с клавиатуры
{
        for(int i=0;i<n;i++)
        {
            cout<<"Введите "<<i+1<<" элемент: ";
            cin>>a[i];
        }
}
void zapol_random(int *a, int n) //заполнение массива случайными числами
{
        srand(time(NULL));
        for(int i=0;i<n;i++)
        {
            a[i]=rand()%100+1;
        }
}
void print_massiv(int *a, int n) //функция вывода массива на консоль
{
    cout<<"\nМассив: ";
    for(int i=0;i<n;i++)
    {
        cout<<a[i]<<"  ";
    }
}
void sortirovka(int *a, int n) //функция сортировки массива
{
    cout<<endl;
    for(int i=0;i<n;i++)
    {
        cout<<i+1<<" итерация: ";
        for(int j=0;j<n;j++)
        {
        cout<<a[j]<<" ";
        }
    cout<<endl;
    }
    int k,max;
    for(int i=0;i<n;i++) // i - номер текущего шага
    {
        k=i;
        max=a[i];
        for(int j=i+1;j<n;j++) // цикл выбора наибольшего элемента
            if(a[j]>max)
            {
                k=j;
                max=a[j]; // k - индекс наибольшего элемента
            }
        a[k]=a[i];
        a[i]=max; // меняем местами наибольший с a[i]
    }
}
int main()
{   setlocale(LC_ALL,"rus");
    cout<<"\tПрограмма сортирует массив методом выбора"<<endl;
    int N, i,v;
    cout<<"\nВведите кол-во элементов: ";
    cin>>N;
    int *arr1=NULL;
    arr1=new int[N];
    do{
    cout<<"\tМеню програми:\nЗаполнить массив: <1>-клавиатура, <2>-случайные числа.";
    cout<<"\nВаш выбор: ";
    cin>>v;
    }while(v<1||v>2);
    switch(v)
    {
    case 1: vvod_klav(arr1,N);
        break;
    case 2: zapol_random(arr1,N);
        break;
    }
    print_massiv(arr1,N);
    sortirovka(arr1,N);
    print_massiv(arr1,N);
    delete []arr1;
    getch();
    return 0;
}
Вопрос по поводу вывода в функции сортировки каждой интерации цикла сортировки на консоль (типа нужно отследить алгоритм)? Где ошибка скажите пожалуйста?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.10.2017, 13:10
Ответы с готовыми решениями:

Добавлять next() каждую итерацию цикла
Всем привет такой вопрос, мне требуется в цикле проверять каждый следующий элемент в списке (это див и их может быть сколько угодно с...

Как взять предпоследнюю итерацию цикла while?
Пишу задачу с циклом while, чтобы он работал пока точность &gt; 0.001: delta = 1 k = 0 while delta &gt; 0.001: #условие выхода из...

Как в C++ запустить текущую итерацию цикла заново
оператор continue переходит к следующей итерации , а мне нужно ещё раз эту же прогнать

2
Заблокирован
15.10.2017, 14:31
Вывод надо делать в цикле, где сортируешь. Ты почему-то сделал отдельный цикл перед сортировкой, который занимается выводом.
0
0 / 0 / 2
Регистрация: 11.10.2016
Сообщений: 116
15.10.2017, 15:14  [ТС]
C++
1
2
3
4
5
6
7
8
9
for(int i=0;i<n;i++)
    {
        cout<<i+1<<" итерация: ";
        for(int j=0;j<n;j++)
        {
        cout<<a[j]<<" ";
        }
    cout<<endl;
    }
Так вывод и есть в функции сортировки
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.10.2017, 15:14
Помогаю со студенческими работами здесь

Как реализовать переход на следующую итерацию внешнего цикла из вложенного?
Есть ли способ завершить или продолжить внешний цикл из вложенного? Пример : for (i = 0; i &lt; 10; i++) { for (j = 0; j &lt; 10; j++)...

Как реализовать переход на следующую итерацию внешнего цикла из вложенного?
Добрый вечер. Возможен ли в C++ переход на следующую итерацию внешнего цикла из вложенного? например: for(int i=0;i&lt;n;i++) ...

Вывести каждый шаг сортировки выбором
Очень прошу помощи в реализации вывода каждого шага сортировки числового массива выбором. Пробовала сама, ничего не выводит. Есть исходная...

Отличие сортировки выбором от сортировки прямым выбором
Препод задала вопрос, на который я не могу найти инфу в инете, если знаете, подскажите. Но нужно сегодня, буду благодарен

Объявляется ли каждую итерацию переменная-счетчик в цикле for?
Всем привет, расскажу историю возникшего вопроса. Отходил я как-то на курсы с++, и там преподаватель (авторитетный вроде программист,...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Если у вас не установлены Android SDK, NDK сделайте это, JDK, то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Перейдите по ссылке:. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru