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

Переставить в обратном порядке элементы массива

09.11.2013, 19:06. Показов 10099. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
У меня такая проблема, не могу понять как переставить в обратном порядке элементы массива, сама задача звучит таким образом: Дан массив размера 10. Переставить в обратном порядке элементы массива, расположенные между его минимальным и максимальным элементами.
Максимальное, Минимальное я нашел, переставил элементы массива в обратном порядке но как сделать что бы максимальное и минимальное остались, а поменялись числа внутри в обратном порядке.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.11.2013, 19:06
Ответы с готовыми решениями:

Переставить в обратном порядке элементы одномерного массива
Помогите решить задачу: "Переставить в обратном порядке элементы одномерного массива, расположенные до первого минимального элемента...

Переставить в обратном порядке элементы одномерного массива
Array72. Дан массив A размера N и целые числа K и L (1 ≤ K < L ≤ N). Переставить в обратном порядке элементы массива, расположенные между...

Переставить в обратном порядке элементы одномерного массива
"Переставить в обратном порядке элементы одномерного массива, расположенные до первого минимального элемента массива." Сам массив...

5
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
09.11.2013, 19:54
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
static void Main(string[] args)
{
    int[] array = { 5, 10, 7, 8, 4, 2, 4, 1, 1, 3 };
    int Min = int.MaxValue, minIndex = -1, Max = int.MinValue, maxIndex = -1;
 
    for (int i = 0; i < array.Length; i++)
    {
        if (array[i] > Max)
        {
            Max = array[i];
            maxIndex = i;
        }
        if (array[i] < Min)
        {
            Min = array[i];
            minIndex = i;
        }
    }
 
    Console.WriteLine("Исходный массив: \t{0}", string.Join(", ", array));
 
    int begin = Math.Min(minIndex, maxIndex) + 1, end = Math.Max(minIndex, maxIndex) - 1;
    for (; begin < end; begin++, end--)
    {
        int tmp = array[begin];
        array[begin] = array[end];
        array[end] = tmp;
    }
    Console.WriteLine("Обработанный массив: \t{0}", string.Join(", ", array));
    Console.Read();
}
0
 Аватар для maxkoshevoi
74 / 74 / 23
Регистрация: 07.11.2013
Сообщений: 539
09.11.2013, 20:46
а почему так нельзя?
int[] array = { 5, 10, 7, 8, 4, 2, 4, 1, 1, 3 };
int r1 = m[0];
System.Array.Reverse(m);
m[0] = m[m.Length];
m[m.Length] = r1;
0
145 / 45 / 16
Регистрация: 10.10.2013
Сообщений: 110
09.11.2013, 20:51
maxkoshevoi,
потому что
Переставить в обратном порядке элементы массива, расположенные между его минимальным и максимальным элементами.
а
C#
1
System.Array.Reverse(m);
перевернет весь массив
вот такая вот наука )
0
 Аватар для maxkoshevoi
74 / 74 / 23
Регистрация: 07.11.2013
Сообщений: 539
09.11.2013, 20:53
Так я потом минимальный и максимальный обратно меняю местами:
C#
1
2
3
4
5
int[] array = { 5, 10, 7, 8, 4, 2, 4, 1, 1, 3 };
System.Array.Reverse(m);
m[0] += m[m.Length];
m[m.Length] = m[0] - m[m.Length];
m[0] -= m[m.Length];
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
09.11.2013, 20:59
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
class Program
    {
        static void Main(string[] args)
        {
            int[] array = { 5, 10, 7, 8, 4, 2, 4, 1, 1, 3 };
            foreach (int i in array)
            {
                Console.Write(i + " ");
            }
            Console.WriteLine();
 
            int minIndex = 0, maxIndex = 0;
 
            for (int i = 0; i < array.Length; i++)
            {
                if (array[i] > array[maxIndex])
                {
                    maxIndex = i;
                }
                else if (array[i] < array[minIndex])
                {
                    minIndex = i;
                }
            }
 
            if (minIndex > maxIndex)
            {
                Swap(ref minIndex, ref maxIndex);
            }
            for (int i = minIndex + 1, j = maxIndex - 1; i < j; i++, j--)
                Swap(ref array[i], ref array[j]);
 
            foreach (int i in array)
            {
                Console.Write(i + " ");
            }
            Console.WriteLine();
            Console.ReadKey();
        }
 
        public static void Swap(ref int a, ref int b)
        {
            int temp = a;
            a = b;
            b = temp;
        }
    }
Добавлено через 44 секунды
maxkoshevoi, максимальный и минимальный != первый и последний
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.11.2013, 20:59
Помогаю со студенческими работами здесь

Переставить в обратном порядке элементы одномерного массива, расположенные до первого минимального элемента массива
1.Переставить в обратном порядке элементы одномерного массива, расположенные до первого минимального элемента массива.(ПОЛНОЕ РЕШЕНИЕ)

Переставить в обратном порядке элементы массива его минимальным и максимальным элементами
Дан массив размера N. Переставить в обратном порядке элементы массива, расположенные между его минимальным и максимальным элементами,...

Переставить в обратном порядке элементы массива, расположенные между его минимальным и максимальным элементами
Здравствуйте! Дан массив размера N. Переставить в обратном порядке элементы массива, расположенные между его минимальным и максимальным...

Дан массив размера N. Переставить в обратном порядке элементы массива, расположенные между его минимальным и максимальны
Дан массив размера N. Переставить в обратном порядке элементы массива, расположенные между его минимальным и максимальным элементами,...

Одномерный массив. Переставить элементы в обратном порядке. Написать метод
В одномерном массиве символов переставить элементы в обратном порядке не используя дополнительных массивов. Код написал. Все работает....


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru