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

Решить транспортную задачу методом потенциалов

19.01.2014, 16:32. Показов 21080. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста. Необходимо написать программу которая решает транспортную задачу методом потенциалов. Препод показал на таблицу(её прилагаю) и сказал чтобы он мог вбить в программу по данной таблице свои числа и она выдавала решение, это всё его задание, никаких подробностей. Надеюсь на вашу помощь.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.01.2014, 16:32
Ответы с готовыми решениями:

Решить задачу методом рекурсивного перебора с возвратом
В Волшебной стране используются монетки достоинством A1, A2,..., AM. Волшебный человечек пришел в магазин и обнаружил, что у него есть...

Решить транспортную задачу
В трех пунктах отправления сосредоточен однородный груз в количествах, соответственно равных 420, 380 и, 400 т. Этот груз необходимо...

Решить задачу симплекс-методом и написать двойственную к ней задачу
решите пожалуйста

15
Заблокирован
19.01.2014, 16:36
Метод потенциалов не самый простой.
Вот тут хорошо написано, должно помочь:

http://cyclowiki.org/wiki/Транспортная_задача
0
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 16:41  [ТС]
Дело в том, что я не умею писать такие программы. А препод сам не знает программирование, он математик, ему главное чтобы решало, а каким методом я думаю неважно.
0
Заблокирован
19.01.2014, 16:50
Так как препод математик, он точно знает каким методом нужно решать (методом потенциалов). Можно, конечно, и венгерский попробывать реализовать, но он, на мой взгляд, сложнее.

Цитата Сообщение от Alligator5 Посмотреть сообщение
Дело в том, что я не умею писать такие программы.
там внизу есть ссылки на программную реализацию. При желании можно переделать под С++.
0
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 17:06  [ТС]
Умел бы я ещё переделывать. Мои одногруппники сдавали показывали ему взятый с сети код без правок, он посмотрел что она работает и поставил им автоматом 5, в код даже не заглядывал. Ему лет 60 уже. Мне хотя бы часть задания что ли решала программа, на тройку хотя бы. Ибо последний экзамен((
0
Заблокирован
19.01.2014, 17:09
А почему вы не можете взять код у одногрупников?
0
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 17:12  [ТС]
Темы разные, мне вот досталась транспортная задача. Он просто дает тему а дальше сами как можете.
0
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
19.01.2014, 17:14
Так вы определитесь- нужен метод потенциалов или любое решение транспортной задачи.
0
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 17:18  [ТС]
В методичке сказано только про него, больше ничего нет. Поэтому нужен метод потенциалов, но если никто не знает как его сделать то попытаюсь сдать с любым. Безвыходное положение((
0
Заблокирован
19.01.2014, 17:22
http://kb.mista.ru/article.php?id=859

пробуйте переделать сами
0
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 18:01  [ТС]
Спасибо за помощь, но такое переделать не в моих силах.

Добавлено через 35 минут
Помогите доработать код
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
115
116
117
118
119
120
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace ConsoleApplication11
{
    class Program
    {
        struct Element
        {
 
            public int Delivery { get; set; }
            public int Value { get; set; }
            public static int FindMinElement(int a, int b)
            {
                if (a > b) return b;
                if (a == b) { return a; }
                else return a;
            }
 
        }
 
        static void Main(string[] args)
        {
            int i = 0;
            int j = 0;
            int n;
            Console.WriteLine("Введите количество A");
            n = Convert.ToInt32(Console.ReadLine());
            int[] a = new int[n];
            Console.WriteLine("Введите количество B");
            int m = Convert.ToInt32(Console.ReadLine());
            int[] b = new int[m];
            Element[,] C = new Element[n, m];
            Console.WriteLine("Введите a[i]");
            for (i = 0; i < a.Length; i++)
            {
                a[i] = Convert.ToInt32(Console.ReadLine());
            }
            Console.WriteLine("Введите b[i]");
            for (j = 0; j < b.Length; j++)
            {
                b[j] = Convert.ToInt32(Console.ReadLine());
            }
            Console.ForegroundColor = ConsoleColor.White;
            Console.WriteLine("Введите C[i][j]");
            for (i = 0; i < n; i++)
            {
                for (j = 0; j < m; j++)
                {
                    Console.Write("a[{0},{1}] = ", i, j);
                    Console.ForegroundColor = ConsoleColor.Red;
                    C[i, j].Value = Convert.ToInt32(Console.ReadLine());
                    Console.ResetColor();
 
                }
            }
            i = j = 0;
 
            while (i < n && j < m)
            {
 
                try
                {
                    if (a[i] == 0) { i++; }
                    if (b[j] == 0) { j++; }
                    if (a[i] == 0 && b[j] == 0) { i++; j++; }
                    C[i, j].Delivery = Element.FindMinElement(a[i], b[j]);
                    a[i] -= C[i, j].Delivery;
                    b[j] -= C[i, j].Delivery;
                }
                catch { }
            }
            for (i = 0; i < n; i++)
            {
                for (j = 0; j < m; j++)
                {
                    if (C[i, j].Delivery != 0)
                    {
                        Console.ForegroundColor = ConsoleColor.Blue;
                        Console.Write("{0}", C[i, j].Value);
                        Console.ForegroundColor = ConsoleColor.Red;
                        Console.Write("({0})", C[i, j].Delivery); Console.ResetColor();
                    }
                    else
                        Console.Write("{0}({1})", C[i, j].Value, C[i, j].Delivery);
                }
                Console.WriteLine();
 
            }
            int ResultFunction = 0;
 
            for (i = 0; i < n; i++)
            {
                for (j = 0; j < m; j++)
                {
 
                    ResultFunction += (C[i, j].Value * C[i, j].Delivery);
 
 
                }
 
 
            }
            Console.WriteLine(" Result = {0}", ResultFunction);
 
 
 
 
 
            Console.ReadLine();
 
 
 
 
        }
    }
}
0
Заблокирован
19.01.2014, 18:08
Это С#, и насколько я понял метод минимального элемента.
А что вы понимаете под доработкой?
0
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 18:13  [ТС]
на 37 строчке кода не работает
0
Заблокирован
19.01.2014, 18:36
Цитата Сообщение от Alligator5 Посмотреть сообщение
на 37 строчке кода не работает
это вы, наверное, не так запускаете. У меня работает.
0
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 18:44  [ТС]
Да, извиняюсь, моя ошибка)
0
0 / 0 / 0
Регистрация: 14.10.2016
Сообщений: 1
14.10.2016, 11:44
Помоги мне тоже) Скинь полную работу пожалуйста : )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.10.2016, 11:44
Помогаю со студенческими работами здесь

Решить задачу методом золотого сечения и методом деления интервала пополам и написать программу на Pascal
Помогите пожалуйста решить задачу:Из всех прямоугольных треугольников,у которых сумма одного катета и гипотенузы равна 1,найти треугольник...

Решить задачу методом Галеркина
Подскажите пожалуйста необходимо решить задачу методом Галеркина. Условие y''-y'cosx+ysinx=sinx, y(-pi)=y(pi)=2. 1) Решить на отрезке ...

Решить задачу методом моделирования
Заводу необходимо выполнить работу в 1000 единиц. Его базовая производительность равна 5 (работа в день) // Завод может вкладывать...

Операционным методом решить задачу Коши, 1
\begin{cases}x'(t)=-x(t)+2y(t)&amp; \text \\ y'(t)=-y+2 &amp; \text \end{cases}y(0)=0;x(0)=1

Операционным методом решить задачу Коши
1. Операционным методом решить задачу Коши y′′−y′ =t^2 , y (0) = 0 , y′(0) = 1. 2. Решить систему линейных д.у.


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
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