Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
1 / 1 / 0
Регистрация: 16.10.2017
Сообщений: 46

Переделать код под делегат Func

02.03.2019, 10:41. Показов 760. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как переделать это код под делегат Func. Очень надо


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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace laba13
{
    class Program
    {
        public delegate double Del(); // описываем делегат 
        static void Main(string[] args)
        {
            Matrix matrix = new Matrix(); 
 
            matrix.Ouptut();
 
            while (true)
            {
                Del del = null; // создаем наш делегат
                Console.WriteLine("Выберите пункт меню");
                Console.WriteLine("1.Посчитать диагональную сумму чисел");
                Console.WriteLine("2.Посчитать седловую точку");
                Console.WriteLine("3.Посчитать среднее арифметическое всей матрицы чисел");
 
                int userSelection = Convert.ToInt32(Console.ReadLine());
 
                switch (userSelection)
                {
                    case 1:
                        del = matrix.DiagonalSumOfNumbers;
                        break;
                    case 2:
                        del = matrix.SaddlePoint; 
                        break;
                    case 3:
                        del = matrix.Average; 
                        break;
                    default:
                        Console.WriteLine("Нет такого пункта меню");
                        break;
                }
 
                Console.WriteLine(del()); // будет вызван метод который щас лежит в делегате и на консоль выведется результат выполнения этого метода
            }
        }
    }
}
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace laba13
{
    class Matrix
    {
        public double [,] Matr;
 
        public Matrix()
        {
            Console.WriteLine("Введите размерность квадратной матрицы");
            int n = Convert.ToInt32(Console.ReadLine());
            Matr = new double[n,n];
 
            for (int i = 0; i < Matr.GetLength(0); i++)
            {
                for (int j = 0; j < Matr.GetLength(1); j++)
                {
                    Console.WriteLine("Введите {0} элемент {1} строки",j+1,i+1);
                    Matr[i,j]= Convert.ToInt32(Console.ReadLine()); 
                }
            }
        }
 
        public void Ouptut()
        {
            for (int i = 0; i < Matr.GetLength(0); i++)
            {
                for (int j = 0; j < Matr.GetLength(1); j++)
                {
                    Console.Write(Matr[i,j]+" ");
                }
                Console.WriteLine();
            }
        }
 
        public double DiagonalSumOfNumbers()
        {
            double sum = 0;
            for (int i = 0; i < Matr.GetLength(0); i++)
            {
                for (int j = 0; j < Matr.GetLength(1); j++)
                {
                    if ((i == j) || // если это главная диагональ
                        (i + j == Matr.GetLength(0))) // или побочная
                        sum += Matr[i, j]; // суммируем
                }
            }
 
            return sum;
        }
 
        public double SaddlePoint() // нахождение седловой точки, если такой нету возвращаем не число
        {
            for (int i = 0; i < Matr.GetLength(0); i++)
            {
                for (int j = 0; j < Matr.GetLength(1); j++) // i,j циклы идут по каждому элементу матрицы 
                {
                    bool isMaxInColumn = true; // для каждого числа создаем переменные является ли максимальным в столбце,
                    bool isMinInLine = true;   // или минимальным в строке
                    for (int k = 0; k < Matr.GetLength(0); k++)//строка
                    {
                        if (Matr[i, j] > Matr[i, k]) isMinInLine = false; // если текующий элемент больше какого либо элемента в строке,
                                                                            // то он не является минимальным
                    }
 
                    for (int z = 0; z < Matr.GetLength(1); z++)// столбец
                    {
                        if (Matr[i, j] < Matr[z, j]) isMaxInColumn = false; // если текующий элемент меньше какого либо элемента в cтолбце,
                                                                            // то он не является максимальным
                    }
 
                    if (isMaxInColumn && isMinInLine) return Matr[i, j]; // если элемент является седловым, то возвращаем его и выходим из метода
                }
            }
            return double.NaN; // если не было найдено ни одного седлового числа, то возвращаем не число
        }
 
        public double Average()
        { 
            double sum = 0;
            for (int i = 0; i < Matr.GetLength(0); i++)
            {
                for (int j = 0; j < Matr.GetLength(1); j++)
                {
                    sum += Matr[i, j];
                }
            }
 
            return sum / Matr.Length;
 
        }
    }
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.03.2019, 10:41
Ответы с готовыми решениями:

Делегат Func с несколькими параметрами в Task<Tresult>
Добрый день. В данный момент начал изучать TPL и возник вопрос по поводу использования параметризованного Task. История следующая: ...

Делегат Func<Action<char>, bool, double, double>
Задание: реализуйте пользовательский тип делегата требуемой сигнатуры и выполните с его использованием вызов нескольких методов (с...

Переделать код под использование пользовательских методов
Есть программа,как ее переделать под 2 пользовательских метода: 1)Который возвращает значение через имя 2)Который возвращает значение...

1
 Аватар для samana
2639 / 1567 / 853
Регистрация: 23.02.2019
Сообщений: 3,876
02.03.2019, 13:11
По идее, просто вместо
C#
1
2
public delegate double Del();
Del del = null;
пишите
C#
1
2
public Func<double> del;
del = null;
и всё..
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.03.2019, 13:11
Помогаю со студенческими работами здесь

Как переделать данный код под работу с большими числами?
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using...

Можно ли как-то "напрямую" передать обобщенный метод в делегат Func
Привет! Есть в Метод1 с параметром типа Func&lt;string, string, IEnumerable&lt;string&gt;&gt;: void MyMethod1(Func&lt;string, string,...

возможно ли переделать код алгоритма под Borland C переделать под Borland Delphi?
Подскажите возможно ли переделать код алгоритма под Borland C переделать под Borland Delphi? У меня есть исходник алгоритма шифрования SEAL...

Переделать код под С++
Переделать код под С++ (или любой другой) function mypractice format long %------------Задание исходных...

Переделать код под c++
Есть код Pascal, нужно его переделать под c++. Но поскольку в этом не особо разбираюсь прошу у вас помощи. Заранее благодарен. Спасибо за...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru