Форум программистов, компьютерный форум, киберфорум
Наши страницы
C# для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.87/15: Рейтинг темы: голосов - 15, средняя оценка - 4.87
proech
11 / 11 / 10
Регистрация: 10.07.2013
Сообщений: 150
#1

Код (метод северо-западного угла) оптимизировать с помощью метода потенциалов

31.12.2013, 16:09. Просмотров 2805. Ответов 1
Метки нет (Все метки)

код считает по методу северо-западного угла
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
121
122
123
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.ForegroundColor = ConsoleColor.Blue;
            Console.WriteLine("Введите количество A");
            n = Convert.ToInt32(Console.ReadLine());
            int[] a = new int[n];
            Console.ForegroundColor = ConsoleColor.Red;
            Console.WriteLine("Введите количество B");
            int m = Convert.ToInt32(Console.ReadLine());
            int[] b = new int[m];
            Element[,] C = new Element[n, m];
            Console.ForegroundColor = ConsoleColor.DarkBlue;
            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;
            // действуем по алгоритму 
 
            // идём с северо-западного элемента 
            // если a[i] = 0 i++
            // если b[j] = 0 j++
            //  если a[i],b[j] = 0 то i++,j++;
            // доходим до последнего i , j
            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);
                i = 0;
                j = 0;
                int[] u = new int[n];
                int[] v = new int[m];
                
         
                         
 
                Console.ReadLine();
 
 
 
 
            
        }
    }
}
как теперь её оптимизировать с помощью метода потенциалов ?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.12.2013, 16:09
Ответы с готовыми решениями:

Транспортная задача. Метод северо-западного угла и метод минимального элемента.
Метод северо-западного угла и метод минимального элемента. Задание: Найти...

Нахождение первоначального распределения транспортной задачи по методу Северо-Западного угла
Народ, нужна помощь. Нужно составить программу &quot;Нахождение первоначального...

Транспортная задача: метод северо-западного угла + метод оптимизации (потенциалов)
есть у кого-нибудь исходники на программу решения злп метод с-з угла + метод...

Метод северо-западного угла!
Можете помочь с методом северо западного угла! Задача состоит в том что я...

Метод северо-западного угла
Здравствуйте! Помогите пожалуйста в написании кода программы по расчету...

1
Ev_Hyper
Заблокирован
31.12.2013, 20:25 #2
метод потенциалов довольно сложен, особенно если учитывать вырожденность и зацикливание...
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
31.12.2013, 20:25

Метод северо-западного угла
надо реализовать данный метод. http://www.reshmat.ru/example_transport_4.html...

Транспортная задача: метод северо-западного угла
Здесь уже была похожая тема, но там так и нет ответа. Программа делает только...

Транспортная задача.Метод северо-западного угла
Всем привет!! люди если не сложно помогите пожалуйста написать программу для...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

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