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

Вывод отсортированного массива 2-мя методами сортировки

29.03.2017, 15:23. Показов 3935. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пишу на Ideone, задание состояло в сортировке массива 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
84
85
86
#include <iostream>
  int SortOtbor(int[], int);// функции сортировка выбором
  int SortObmen(int[], int);// функции сортировка обменом 
using namespace std;
 
int main() {
 
int V;
   cout<<"Введите номер варианта"<<endl;
   cin>>V;
int size = 50+2*V; //размер массива
int array[size] = {};
int array2[size]={};//создаем еще один массив, чтобы обе функции использовали один и тот же массив
 
 
 
 
//заполним массивы случайными числами от 1 до 100
srand(time(NULL));
 
for(int i = 0; i < size; i++)
{
   array[i] = 1 + rand() % 100;
   array2[i] = array[i];//копируем значения первого массива во второй, чтобы использовать его в другой функции 
   }
 
//выводим неотсортированный массив на экран
cout << "Неотсортированный массив: " << endl;
for (int i = 0; i < size; i++)
   cout <<array[i]<<" ";
 
cout << endl << endl;
  
//выводим отсортированный массив (выбором) на экран
cout << "Отсортированный массив (выбором): " << endl;
for (int i = 0; i < size; i++)
   cout <<array[i]<<" ";
 
cout << endl << endl;
  
//выводим отсортированный массив (обмена) на экран
cout << "Отсортированный массив (обменом): " << endl;
   for (int i = 0; i < size; i++)
cout <<array2[i]<<" ";
 
cout << endl << endl;
    return 0;
}
 
///////////////////////////////////////////////////////////////////////////
int SortOtbor(int array[], int size)
{
int temp;
    for(int i = 0; i < size; ++i) // i - номер текущего шага
    { 
        int pos = i; 
        temp = array[i];
        for(int j = i + 1; j < size; ++j) // цикл выбора наименьшего элемента
        {
            if (array[j] < temp) 
           {
               pos = j; 
               temp = array[j]; 
           }
        }
        array[pos] = array[i]; 
        array[i] = temp; // меняем местами наименьший с a[i]
    }
}
//////////////////////////////////////////////////////////////////////////
int SortObmen(int array2[], int size)
{
    int temp;
    for(int i = 0; i < size - 1; ++i) // i - номер прохода
    {            
        for(int j = 0; j < size - 1; ++j) // внутренний цикл прохода
        {     
            if (array2[j + 1] < array2[j]) 
            {
                temp = array2[j + 1]; 
                array2[j + 1] = array2[j]; 
                array2[j] = temp;
            }
        }
    }   
}
Добавлено через 18 часов 18 минут
Я дэлбич, уже выводит отсортированный массив 2-мя способами, но не считает количество обменов и перестановок(выводит просто "0"), объявлял их как глобальные, но и это тоже не помогает, можно ли решить проблему не прибегая к указателям?
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#include <iostream>
#include <ctime>
int SortVibor(int[], int,int,int);
int SortObmen(int[], int,int,int); 
using namespace std;
 
int main()
{
    int V;
        cout<<"Введите номер варианта"<<endl;
        cin>>V;
    int size = 50+2*V; //размер массива
    int array[size] = {};
    int array2[size]= {};//создаем еще один массив, чтобы обе функции использовали один и тот же массив
    //заполним массивы случайными числами от 1 до 100
srand(time(NULL));
    for(int i = 0; i < size; i++)
    {
        array[i] = 1 + rand() % 100;
        array2[i] = array[i];//копируем значения первого массива во второй, чтобы использовать его в другой функции 
    }
    //выводим неотсортированный массив на экран
    cout << "Неотсортированный массив: " << endl;
    for (int i = 0; i < size; i++)
    {
        cout <<array[i]<<" ";
    } 
    cout << endl << endl;
    /////////////////////////////////////////////////выводим отсортированный массив (выбором) на экран
    int count_2compare=0;
    int count_2switch = 0;
    SortVibor(array,size,count_2compare,count_2switch);
    cout << "Отсортированный массив (выбором): " << endl;
    for (int i = 0; i < size; i++)
    {
        cout <<array[i]<<" ";
    } 
    cout<<endl;
    cout<<"Количество сравнений"<<" "<<count_2compare<<endl;
    cout<<"Количество обменов"<<" "<<count_2switch<<endl;;
    cout << endl << endl;
    ///////////////////////////////////////////////выводим отсортированный массив (обмена) на экран
    int count_compare = 0;
    int count_switch = 0;
    SortObmen(array2,size,count_compare,count_switch);
    cout << "Отсортированный массив (обменом): " << endl;
    for (int i = 0; i < size; i++)
    {
        cout <<array2[i]<<" ";
    } 
    cout<<endl;
    cout<<"Количество сравнений"<<" "<<count_compare<<endl;
    cout<<"Количество обменов"<<" "<<count_switch<<endl;;
    cout << endl << endl;
return 0;
}
/////////////////////////////////////////////////////////////////////////////////////////
int SortVibor(int array[], int size,int count_2compare,int count_2switch)
{
int min;
    for(int i = 0; i < size; ++i) // i - номер текущего шага
    { 
        int pos = i; 
        min = array[i];
        count_2compare+=1;
        for(int j = i + 1; j < size; ++j) // цикл выбора наименьшего элемента
        {
            if (array[j] < min) 
           {
               pos = j; 
               min = array[j]; 
               count_2switch+=1;
           }
            count_2compare+=1;
        }
        array[pos] = array[i]; 
        array[i] = min; // меняем местами наименьший с array[i]
    }
}
////////////////////////////////////////////////////////////////////////////////////////
int SortObmen(int array2[], int size, int count_compare,int count_switch)
{
    int temp;
    for(int i = 0; i < size - 1; ++i) // i - номер прохода
    {            
        count_compare+=1;
        for(int j = 0; j < size - 1; ++j) // внутренний цикл прохода
        {     
            if (array2[j + 1] < array2[j]) 
            {
                temp = array2[j + 1]; 
                array2[j + 1] = array2[j]; 
                array2[j] = temp;
                count_switch+=1;
            }
            count_compare+=1;
        }
    }   
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.03.2017, 15:23
Ответы с готовыми решениями:

Вывод отсортированного массива с индексами элементов до сортировки
ЗАДАЧА: известны номера пловцов от 0 до n. Необходимо определить по результатам соренований, какое место занял каждый спортсмен. Считается,...

Вывод отсортированного массива в 16-ричной системе
есть массив заполненный делаю sort ....и хочу чтобы вывод был в 16-ричной системе,не получается((( sort(arr.begin(), arr.end()); p =...

Вывод отсортированного массива,в текстовой файл
В общем,написан код сортировки по убыванию в столбце,запускаю прогу,он правильно сортирует но в текстовой файл не записывает cout...

2
63 / 61 / 37
Регистрация: 01.04.2015
Сообщений: 116
29.03.2017, 15:32
Передавай по ссылке:
C++
1
2
3
4
5
6
7
8
int SortVibor(int array[], int size,int &count_2compare,int &count_2switch)
{
    ...
}
int SortObmen(int array2[], int size, int &count_compare,int &count_switch)
{
    ...
}
1
1 / 1 / 3
Регистрация: 27.01.2015
Сообщений: 116
29.03.2017, 15:37
Ну так хотя бы:
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include <iostream>
#include <ctime>
int SortVibor(int[], int);
int SortObmen(int[], int); 
using namespace std;
 
int main()
{
    int V;
        cout<<"Введите номер варианта"<<endl;
        cin>>V;
    int size = 50+2*V; //размер массива
    int array[size] = {};
    int array2[size]= {};//создаем еще один массив, чтобы обе функции использовали один и тот же массив
    //заполним массивы случайными числами от 1 до 100
srand(time(NULL));
    for(int i = 0; i < size; i++)
    {
        array[i] = 1 + rand() % 100;
        array2[i] = array[i];//копируем значения первого массива во второй, чтобы использовать его в другой функции 
    }
    //выводим неотсортированный массив на экран
    cout << "Неотсортированный массив: " << endl;
    for (int i = 0; i < size; i++)
    {
        cout <<array[i]<<" ";
    } 
    cout << endl << endl;
    /////////////////////////////////////////////////выводим отсортированный массив (выбором) на экран
  
    SortVibor(array,size);
    cout << "Отсортированный массив (выбором): " << endl;
    for (int i = 0; i < size; i++)
    {
        cout <<array[i]<<" ";
    } 
    cout<<endl;
 
    cout << endl << endl;
    ///////////////////////////////////////////////выводим отсортированный массив (обмена) на экран
 
    SortObmen(array2,size);
    cout << "Отсортированный массив (обменом): " << endl;
    for (int i = 0; i < size; i++)
    {
        cout <<array2[i]<<" ";
    } 
    cout<<endl;
    
    cout << endl << endl;
return 0;
}
/////////////////////////////////////////////////////////////////////////////////////////
int SortVibor(int array[], int size)
{
int count_2compare=0, count_2switch=0;
int min;
    for(int i = 0; i < size; ++i) // i - номер текущего шага
    { 
        int pos = i; 
        min = array[i];
        count_2compare+=1;
        for(int j = i + 1; j < size; ++j) // цикл выбора наименьшего элемента
        {
            if (array[j] < min) 
           {
               pos = j; 
               min = array[j]; 
               count_2switch+=1;
           }
            count_2compare+=1;
        }
        array[pos] = array[i]; 
        array[i] = min; // меняем местами наименьший с array[i]
    }
       cout<<"Количество сравнений"<<" "<<count_2compare<<endl;
    cout<<"Количество обменов"<<" "<<count_2switch<<endl;
}
////////////////////////////////////////////////////////////////////////////////////////
int SortObmen(int array2[], int size)
{
    int temp; int count_compare=0, count_switch=0;
    for(int i = 0; i < size - 1; ++i) // i - номер прохода
    {            
        count_compare+=1;
        for(int j = 0; j < size - 1; ++j) // внутренний цикл прохода
        {     
            if (array2[j + 1] < array2[j]) 
            {
                temp = array2[j + 1]; 
                array2[j + 1] = array2[j]; 
                array2[j] = temp;
                count_switch+=1;
            }
            count_compare+=1;
        }
    }   
    cout<<"Количество сравнений"<<" "<<count_compare<<endl;
    cout<<"Количество обменов"<<" "<<count_switch<<endl;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.03.2017, 15:37
Помогаю со студенческими работами здесь

Неверный вывод отсортированного массива чисел с плавающей точкой
Когда эту же программу запускаю не в потоке, выводит все правильно. #include &lt;iostream&gt; #include &lt;cstdlib&gt; #include...

Вывод массива после сортировки
У меня не работает правельно вывод массива после сортировки, он такой же как и вводил, помогите. #include &lt;iostream.h&gt; #include ...

Поэтапный вывод сортировки массива
C меня за помощь 100 рублей на webmoney. скайп komarov.deen icq 3556353 Нужно поэтапно вывести сортировку массива, код имеется: ...

Алгоритм почти отсортированного массива
Я ищу его по всему интернету без результатно, может кто подскажет?

Вывести часть отсортированного массива
Сформировать одномерный массив целых случайных чисел. удалить все элементы, большие данного числа x (x ввести с клавиатуры) .Вывести ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение Это мой обзор планшета X220 с точки зрения школьника. Недавно я решила попытаться уменьшить свой. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru