Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 08.05.2021
Сообщений: 3
.NET 3.x

Найти минимальное число перестановок для равновесия элементов массива

08.05.2021, 15:41. Показов 1010. Ответов 2

Студворк — интернет-сервис помощи студентам
Элементы можно передвигать только стоящие рядом. Небходимо найти минимальное число перестановок для равновесия элементов массива.

in = [1, 5, 9, 10, 5]

avr = sum/lenght

out = [6, 6, 6, 6, 6]

MIN number of element move = 12


Кликните здесь для просмотра всего текста

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
using System;
                    
public class Program
{
    public static void Main()
    {
        int[] arr = new int[] { 1, 5, 9, 10, 5 };   
        int n = arr.Length;
        int last = arr[n - 1];
        int count = 0;
        int avr = 0;
        int sum = 0;
        int rem, buf, temp;
        int max = 0;
        
        
        //sum and avarage
        for (int i = 0; i < n; i++) 
        {
            sum += arr[i];
        }
        avr = sum / n;
        Console.Write("sum: " + sum + " avr: " + avr);
        Console.WriteLine();
        
        
        //max
        for (int i = 0; i < n; i++)
        {
            if (arr[i] > arr[max]) 
            {
                max = i;
            }
        }
        Console.WriteLine("[max element]: " + max);
        
        //check
        for (int i = 0; i < n; i++)
        {
            if ((arr[max] > avr) && (arr[max-1] > arr[max+1]))
            {
                buf = arr[max] - avr;
                arr[max] -= buf;
                
                rem = arr[max+1] + buf;
                arr[max+1] = rem;
 
                count += buf;
            }
        }
        
        //shift
        for (int i = arr.Length - 2; i >= 0; i--)
        {
            arr[i + 1] = arr[i];
        }
        arr[0] = last;
        
        Console.WriteLine();
        
        //print
        for (int i = 0; i < n; i++)
        {
            Console.Write(arr[i] + " ");
        }
        Console.WriteLine("\n" + "coutn: " + count);
    }
}


Ответ был просчитан на листке бумаги - за 12 ходов можно распределить значения по массиву. Меня интересует только это условие `while(arr[max] != avr)`, как его прописать, чтобы менялись все элементы массива на значение = 6?

Результат работы программы:
sum: 30
avr: 6
max element: 3

out array: 5 1 5 9 6
count: 4
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.05.2021, 15:41
Ответы с готовыми решениями:

Найти минимальное количество перестановок соседних элементов последовательности, необходимое для того, чтобы отсортировать ее по возрастанию
Делал пузырьком - не проходит по времени. Посоветовали использовать сортировку слиянием. #include&lt;stdio.h&gt; int flag; ...

Найти минимальное число k, такое, что сумма первых k элементов массива превосходит заданное число
написать программу, выполняющую поиск такого минимального k, что сумма первых k элементов массива превосходит заданное число s

Найти минимальное число среди положительных элементов массива
Найти минимальное число среди положительных элементов массива А(1:70)

2
0 / 0 / 0
Регистрация: 08.05.2021
Сообщений: 3
08.05.2021, 19:45  [ТС]
Код работает, но проблема в том, что изменяется 2 последних элемента. Как прописать условие (утрамбовать в цикл всю эту портянку из других циклов) чтобы все элменты заменились на 6 6 6 6 6? Понятно, что условие должно быть типа такого while (arr[max] != avr).
Изображения
 
0
0 / 0 / 0
Регистрация: 08.05.2021
Сообщений: 3
13.05.2021, 13:37  [ТС]
Задача решена.
Можно закрывать/удалять тему.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.05.2021, 13:37
Помогаю со студенческими работами здесь

Найти минимальное положительное число среди 14 элементов массива
Вот характеристика последовательности: Минимальное положительное число; n=14; Сделать нужно в учебной модели ЭВМ Жмакина. Тему сам не...

Найти минимальное число среди элементов массива с индексом, кратным 3
1.Найти минимальное число среди элементов массива Е, индекс которых кратный 3 ( N -количество элементов -21; числа от -12 до 14) ...

Найти минимальное натуральное число, не представимое суммой никаких элементов массива P
Составьте программу поиска минимального натурального числа, не представимого суммой никаких элементов массива P(N). Сумма может состоять и...

Определить минимальное число перестановок местами пар чисел
Дано L чисел,которые принимают значения от 1 до L и расположены в произвольном порядке.Определить минимальное число перестановок местами...

Составить программу, которая определяет минимальное число перестановок томов
Многотомное собрание сочинений (не более чем из 32 томов) стоит в произвольном порядке на полке. Разрешается брать любой том, и ставить его...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru