Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 18, средняя оценка - 5.00
Alligator5
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 16:32     Решить транспортную задачу методом потенциалов #1
Помогите пожалуйста. Необходимо написать программу которая решает транспортную задачу методом потенциалов. Препод показал на таблицу(её прилагаю) и сказал чтобы он мог вбить в программу по данной таблице свои числа и она выдавала решение, это всё его задание, никаких подробностей. Надеюсь на вашу помощь. Решить транспортную задачу методом потенциалов
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.01.2014, 16:32     Решить транспортную задачу методом потенциалов
Посмотрите здесь:

Решить задачу на C++ C++
C++ Не получается решить задачу
C++ Как решить задачу?
помогите решить задачу C++
Транспортная задача (методом потенциалов) C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ev_Hyper
 Аватар для Ev_Hyper
1807 / 1628 / 435
Регистрация: 15.12.2013
Сообщений: 5,790
19.01.2014, 16:36     Решить транспортную задачу методом потенциалов #2
Метод потенциалов не самый простой.
Вот тут хорошо написано, должно помочь:

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

Цитата Сообщение от Alligator5 Посмотреть сообщение
Дело в том, что я не умею писать такие программы.
там внизу есть ссылки на программную реализацию. При желании можно переделать под С++.
Alligator5
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 17:06  [ТС]     Решить транспортную задачу методом потенциалов #5
Умел бы я ещё переделывать. Мои одногруппники сдавали показывали ему взятый с сети код без правок, он посмотрел что она работает и поставил им автоматом 5, в код даже не заглядывал. Ему лет 60 уже. Мне хотя бы часть задания что ли решала программа, на тройку хотя бы. Ибо последний экзамен((
Ev_Hyper
 Аватар для Ev_Hyper
1807 / 1628 / 435
Регистрация: 15.12.2013
Сообщений: 5,790
19.01.2014, 17:09     Решить транспортную задачу методом потенциалов #6
А почему вы не можете взять код у одногрупников?
Alligator5
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 17:12  [ТС]     Решить транспортную задачу методом потенциалов #7
Темы разные, мне вот досталась транспортная задача. Он просто дает тему а дальше сами как можете.
S_el
1908 / 1503 / 296
Регистрация: 15.12.2013
Сообщений: 5,920
19.01.2014, 17:14     Решить транспортную задачу методом потенциалов #8
Так вы определитесь- нужен метод потенциалов или любое решение транспортной задачи.
Alligator5
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 17:18  [ТС]     Решить транспортную задачу методом потенциалов #9
В методичке сказано только про него, больше ничего нет. Поэтому нужен метод потенциалов, но если никто не знает как его сделать то попытаюсь сдать с любым. Безвыходное положение((
Ev_Hyper
 Аватар для Ev_Hyper
1807 / 1628 / 435
Регистрация: 15.12.2013
Сообщений: 5,790
19.01.2014, 17:22     Решить транспортную задачу методом потенциалов #10
http://kb.mista.ru/article.php?id=859

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

Добавлено через 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();
 
 
 
 
        }
    }
}
Ev_Hyper
 Аватар для Ev_Hyper
1807 / 1628 / 435
Регистрация: 15.12.2013
Сообщений: 5,790
19.01.2014, 18:08     Решить транспортную задачу методом потенциалов #12
Это С#, и насколько я понял метод минимального элемента.
А что вы понимаете под доработкой?
Alligator5
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 18:13  [ТС]     Решить транспортную задачу методом потенциалов #13
на 37 строчке кода не работает
Ev_Hyper
 Аватар для Ev_Hyper
1807 / 1628 / 435
Регистрация: 15.12.2013
Сообщений: 5,790
19.01.2014, 18:36     Решить транспортную задачу методом потенциалов #14
Цитата Сообщение от Alligator5 Посмотреть сообщение
на 37 строчке кода не работает
это вы, наверное, не так запускаете. У меня работает.
Alligator5
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
19.01.2014, 18:44  [ТС]     Решить транспортную задачу методом потенциалов #15
Да, извиняюсь, моя ошибка)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.10.2016, 11:44     Решить транспортную задачу методом потенциалов
Еще ссылки по теме:

Транспортная задача (методом потенциалов) C++
C++ Решить задачу методом рекурсивного перебора с возвратом
Решить уравнение по заданной формуле методом хорд и модифицированным методом Ньютона C++

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

Или воспользуйтесь поиском по форуму:
Doter2
0 / 0 / 0
Регистрация: 14.10.2016
Сообщений: 1
14.10.2016, 11:44     Решить транспортную задачу методом потенциалов #16
Помоги мне тоже) Скинь полную работу пожалуйста : )
Yandex
Объявления
14.10.2016, 11:44     Решить транспортную задачу методом потенциалов
Ответ Создать тему
Опции темы

Текущее время: 14:36. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru