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

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

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

Author24 — интернет-сервис помощи студентам
Помогите пожалуйста. Необходимо написать программу которая решает транспортную задачу методом потенциалов. Препод показал на таблицу(её прилагаю) и сказал чтобы он мог вбить в программу по данной таблице свои числа и она выдавала решение, это всё его задание, никаких подробностей. Надеюсь на вашу помощь.
Решить транспортную задачу методом потенциалов
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,241
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
Ответ Создать тему
Новые блоги и статьи
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
Сложность Колмогорова: Приёмы упрощения кода
ArchitectMsa 20.03.2025
Наверное, каждый программист хотя бы раз сталкивался с кодом, который напоминает запутанный лабиринт — чем дальше в него погружаешься, тем сложнее найти выход. И когда мы говорим о сложности кода, мы. . .
PostgreSQL в Kubernetes: Подготовка кластера и настройка
Mr. Docker 20.03.2025
Когда доходит до контейнеризации баз данных и особенно таких требовательных к ресурсам системах как PostgreSQL, многие команды до сих пор колеблются, прежде чем перенести их в контейнерную. . .
C++26: Индексирование пакетов и метапрограммиро­вание
bytestream 20.03.2025
Эволюция C++ продолжается стремительными темпами – каждый новый стандарт приносит функциональность, о которой мы мечтали годами. Звучит слишком громко? Если вы когда-либо боролись с вариадическими. . .
Состояние гонки в C#: подводные камни многопоточного программировани­я
UnmanagedCoder 20.03.2025
Что такое состояние гонки? Это ситуация, когда результат программы непредсказуемо меняется в зависимости от порядка выполнения потоков. Проще говоря, два или более потока пытаются одновременно. . .
Next.js для разработки React: преимущества серверного рендеринга
Reangularity 20.03.2025
Next. js решает классическую проблему React-приложений: медленную первоначальную загрузку и плохую индексацию поисковиками. Вместо того чтобы заставлять браузер пользователя выполнять всю работу по. . .
JUnit или TestNG: Выбираем Java-фреймворк для тестирования
Javaican 20.03.2025
История тестовых фреймворков в Java началась в конце 90-х, когда Кент Бек и Эрих Гамма разработали JUnit - инструмент, который перевернул представление разработчиков о модульном тестировании. JUnit. . .
Разбиваем монолит на два микросервиса и реализуем CI/CD
ArchitectMsa 20.03.2025
Когда команда растет, а функциональность монолита расширяется, поддерживать и развивать такую систему становится все труднее. Разработчики начинают тратить много времени на разбор сложных. . .
Python и PDF: Создание и редактирование файлов
py-thonny 20.03.2025
Работа с PDF-документами – одна из популярных задач в современной разработке. Python предлагает несколько инструментов для создания, чтения и редактирования PDF-файлов, среди которых особенно. . .
Корутины в Unity и производительно­сть WaitForSeconds
GameUnited 20.03.2025
Разработчики игр на Unity часто сталкиваются с вопросом: как выполнять действия через определённые промежутки времени, не блокируя основной поток игры? Тут как раз и приходят на помощь корутины —. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер