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

Упорядочивать копии исходного массива тремя алгоритмами: обменом, выбором, вставками

09.01.2014, 00:49. Показов 1493. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать код решения поставленной задачи.
Размерность массива вводится пользователем вручную с клавиатуры.
Элементы массива вводятся либо пользователем вручную с клавиатуры либо генерируются с помощью генератора случайных чисел. Выбор одного из способов предоставляется пользователю.
Упорядочивать копии исходного массива тремя алгоритмами: обменом, выбором, вставками. Т.е. для реализации каждого алгоритма создавать новую копию исходного массива.
Расположить в порядке возрастания все элементы массива из n целых чисел до его середины.
Тест1 - n=7, a[i]=1,8,2,4,3,2,9 --- a[i]=1,2,4,8,3,2,9.
Тест2 - n=6, a[i]=2,3,0,8,-2,6 --- a[i]=0,2,3,8,-2,6.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.01.2014, 00:49
Ответы с готовыми решениями:

реализ. сортировку массива лин. выбором с обменом
Помогите пожалуйста написанием задачи в С++ =) Необходимо: реализовать сортировку массива линейным выбором с обменом. Добавлено...

Сортировка выбором с обменом неотсортированного массива из 1000 элементов
#include <stdio.h> #define MAS 1000 void main(void) { int S; int P; int j = 0; int i = 0; S = MAS; int MIN;

Сортировка массивов тремя алгоритмами
Реализовать три алгоритма сортировки,

1
4 / 4 / 7
Регистрация: 15.01.2014
Сообщений: 11
19.01.2014, 18:25
Лучший ответ Сообщение было отмечено MaryiaA как решение

Решение

Кликните здесь для просмотра всего текста
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
using System;
using System.Collections.Generic;
 
namespace MaryiaA
{
    class Program
    {
        static void print (string s, int[] A)
        {
            Console.WriteLine(s);
            for (int i = 0; i < A.Length; i++)
            {
                Console.Write(A[i] + "  ");
            }
            Console.WriteLine();
        }
        static void Main()
        {
            int i, j, n, tmp, min;
            List<char> yes = new List<char>() { 'Y', 'y', 'Н', 'н' };
            List<char> no = new List<char>() { 'N', 'n', 'Т', 'т' };
            char key;
            Random rnd = new Random();
            Console.Write("Введите размерность массива: ");
            n = Convert.ToInt32(Console.ReadLine());
            int[] a = new int[n];
            Console.Write("Заполнить массив вручную (Y) или сгенеривать случайно (N)...");
            do
            {
                key = Console.ReadKey(true).KeyChar;
            } while (!(yes.Contains(key)) && !(no.Contains(key)));
            if (yes.Contains(key))
            {
                Console.WriteLine("Yes");
                Console.WriteLine("Введите целые числа через пробел:");
                string s = Console.ReadLine();
                string[] temp = s.Split(' ');
                for (i = 0; i < n; i++)
                {
                    try
                    {
                        a[i] = int.Parse(temp[i]);
                    }
                    catch (Exception)
                    {
                        a[i] = 0;                        
                    }
                }
                print("Вы ввели массив (некорректные данные преобразованы в 0):", a);
            }
            else if (no.Contains(key))
            {
                Console.WriteLine("No");
                for (i = 0; i < n; i++)
                {
                    a[i] = rnd.Next(20);
                    
                }
                print("Рандомный массив:", a);
            }
            Console.WriteLine("\nОТСОРТИРОВАННЫЕ ДО СЕРЕДИНЫ МАССИВЫ:");
            //сортировка обменом (пузырьком)
            int[] a1 = new int[n];
            Array.Copy(a, a1, n);
            for (j = 0; j < n/2-1; j++)
            {
                for (i = 0; i < n/2-1-j; i++)
                {
                    if (a1[i]>a1[i+1])
                    {
                        tmp = a1[i];
                        a1[i] = a1[i + 1];
                        a1[i + 1] = tmp;
                    }
                }
            }
            print("  алгоритмом обмена (пузырьком)", a1);
            //алгоритм выбора
            int[] a2 = new int[n];
            Array.Copy(a, a2, n);
            for (i = 0; i < n/2 - 1; i++)
            {
                min = i;
                for (j = i + 1; j < n/2; j++)
                {
                    if (a2[j] < a2[min])
                    {
                        min = j;
                    }
                }
                tmp = a2[i];
                a2[i] = a2[min];
                a2[min] = tmp;
            }
            print("  алгоритмом выбора", a2);
            //алгоритм вставки
            int[] a3 = new int[n];
            Array.Copy(a, a3, n);
            for (i = 0; i < n/2; i++)
            {
                tmp = a3[i];
                j = i - 1;
                while ((j >= 0) && (a3[j]>tmp))
                {
                    a3[j + 1] = a3[j];
                    a3[j] = tmp;
                    j--;
                }
            }
            print("  алгоритмом вставки", a3);
            Console.ReadKey(true);
        }
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.01.2014, 18:25
Помогаю со студенческими работами здесь

Если создать копию открытого массива, то изменение исходного массива или его копии приводит к изменению обоих
Столкнулся с проблемой, что если создать копию открытого массива, то изменение исходного массива или его копии приводит к изменению обоих....

Нахождение степени числа тремя разными алгоритмами
здравствуйте. можете подсказать, мне нужно найти число a в степени n тремя разными алгоритмами. почитал литературу и всё-равно не могу...

Сортировка линейным выбором с обменом
Надо отсортировать массив по возрастанию и убыванию линейным выбором. Всё идет нормально, но возникает ошибка:procedure...

Отсортировать массивы выбором, обменом и по увеличению
15: Количество элементов массива. Integer: Тип элементов массива. Выбором: первый сортировки. Обменом: второй сортировки. По увеличению:...

Расставить элементы массива в порядке возрастания методом сортировки выбором и сортировки простыми вставками
Здрасьте еще раз!С прошедшим вас праздником! я глупая и бестолковая опять пришла к вам на спасение. задачка вот простенькая, но вся...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru