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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 18, средняя оценка - 5.00
Alligator5
0 / 0 / 0
Регистрация: 13.12.2013
Сообщений: 12
#1

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

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

Помогите пожалуйста. Необходимо написать программу которая решает транспортную задачу методом потенциалов. Препод показал на таблицу(её прилагаю) и сказал чтобы он мог вбить в программу по данной таблице свои числа и она выдавала решение, это всё его задание, никаких подробностей. Надеюсь на вашу помощь. Решить транспортную задачу методом потенциалов
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.01.2014, 16:32
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Решить транспортную задачу методом потенциалов (C++):

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

Транспортная задача (методом потенциалов) - C++
В универе задали сделать транспортную задачу. Знания только одного семестра ОП. Сделал заполнение таблицы поиск потенциала и проверку...

Транспортная задача (методом потенциалов) - C++
Доброго времени суток форумчане! Нужна прога по вычислению транспортной задачи методом потенциалов. Пытался сам сделать, но как-то не...

Решить уравнение по заданной формуле методом хорд и модифицированным методом Ньютона - C++
8. Решить уравнение 5sinx - x = 0 на отрезке с точностью E методом хорд и модифицированным методом Ньютона.

Решить нелинейное уравнение методом хорд и методом простой итерации - C++
Help, please, послезавтра сдавать лабу, а я не знаю как делать=( Нужно решить нелинейное уравнение методом хорд и методом простой...

Решить задачу на C++ - C++
Пожалуйста! Очень срочно! Помогите. Нужно решить задачу на C++. Необходимо решить только под номером 24 в прикрепленном изображении....

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Ev_Hyper
Заблокирован
19.01.2014, 16:36 #2
Метод потенциалов не самый простой.
Вот тут хорошо написано, должно помочь:

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

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

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

Как решить задачу? - C++
Вводим 8 городов, количество жителей, статус (мегаполис больше 25 тыс., город меньше 25 тыс., поселок городского типа до 5000). Вывести...

Не получается решить задачу - C++
Поле first — вещественное число, левая граница диапазона; поле second — вещественное число, правая граница диапазона. Реализовать метод...

помогите решить задачу - C++
Написати програму в C++ яку водиться: Дата/Місяць/Рік і виводитись має Місяць/День/Рік але вводитись має число а виводитись...

Решить задачу с использованием рекурсии - C++
Функция f(n) определена для целых положительных чисел следующим образом: f(n)=1, если n=1 или f(n)=сумма f(nDIVi) по i от 2 до...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
19.01.2014, 18:44
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru