Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
20 / 19 / 4
Регистрация: 22.03.2018
Сообщений: 701
.NET 4.x

Массив: В заданной матрице N * M найти максимальное количество нулей, из которого можно построить прямоугольник...

24.01.2019, 08:22. Показов 1623. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дана матрица N*M. Необходимо в этой матрице найти максимальное количество нулей, из которого можно построить прямоугольник, и вывести его на экран как новую матрицу.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.01.2019, 08:22
Ответы с готовыми решениями:

В матрице найти максимальное количество нулей, из которых можно построить прямоугольник
Данна матрица N*M не обходимо в этой матрице найти максимально количество нулей из которого можно построить прямоугольник и вывести его на...

В заданной матрице состоящей из нулей и единиц найти квадратную подматрицу, состоящую целиком из нулей
Черный квадрат. В матрице состоящей из 0 и 1 найти квадрат заданного размера(квадратную подматрицу), состоящий целиком из нулей.

Двумерный массив. Найти: максимальное из чисел, встречающихся в заданной матрице более одного раза
Найти: максимальное из чисел, встречающихся в заданной матрице более одного раза Матрица: 2 4 7 6 5 8 9 34 43 4 34 53 45 345 3 6 5 56...

3
 Аватар для NnineBfive
1 / 1 / 1
Регистрация: 07.11.2018
Сообщений: 68
24.01.2019, 12:21
Nikita110001, максимальное количество нулей, что имеешь ввиду? и откуда берутся числа в матрице и она сама? и какова новая матрица должна быть?
0
95 / 74 / 27
Регистрация: 13.08.2018
Сообщений: 203
24.01.2019, 13:17
Лучший ответ Сообщение было отмечено Nikita110001 как решение

Решение

Кликните здесь для просмотра всего текста
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace ConsoleApp10
{
    class Program
    {
        static void Main(string[] args)
        {
            int[,] a = {
               { 0,0,0,0,  1,1,0,0,0 },
               { 1,0,1,0,  0,0,0,0,0 },
               { 1,1,1,0,  0,1,0,0,0 },
               { 1,1,1,1,  1,0,0,0,0 },
                           
               { 0,0,0,0,  0,0,0,0,0 },
               { 0,0,0,0,  0,0,0,0,0 },
               { 0,0,0,0,  0,0,0,0,0 },
               { 0,0,0,0,  0,0,0,0,0 }             
               
            };
            print(a);
 
            Console.WriteLine();
 
            insert(a);
 
            print(a);
        }
        public static bool insert(int[,] a)
        {
            int maxSum = int.MinValue;
            int maxRowStart = -1;
            int maxColStart = -1;
            int maxRowEnd = -1;
            int maxColEnd = -1;
 
            for (int rowStart = 0; rowStart < a.GetLength(0); rowStart++)
            {
                for (int colStart = 0; colStart < a.GetLength(1); colStart++)
                {
                    for (int rowEnd = 0; rowEnd < a.GetLength(0); rowEnd++)
                    {
                        for (int colEnd = 0; colEnd < a.GetLength(1); colEnd++)
                        {
                            int sum = 0;
                            bool found = true;
                            for (int row = rowStart; row <= rowEnd; row++)
                            {
                                for (int col = colStart; col <= colEnd; col++)
                                {
                                    found &= a[row, col] != 1;
                                    sum += 1;
                                }
                            }
                            if (found && sum > maxSum)
                            {
                                maxSum = sum;
                                maxRowStart = rowStart;
                                maxColStart = colStart;
                                maxRowEnd = rowEnd;
                                maxColEnd = colEnd;
                            }
                        }
                    }
                }
            }
 
            if (maxRowStart < 0) return false;
 
            for (int row = maxRowStart; row <= maxRowEnd; row++)
            {
                for (int col = maxColStart; col <= maxColEnd; col++)
                {
                    a[row, col] = 2;
                }
            }
 
            return true;
        }
        static void print(int[,] data)
        {
            var color =new [] { ConsoleColor.White, ConsoleColor.Black, ConsoleColor.Green };
 
            for (int i = 0; i < data.GetLength(0); i++)
            {
                for (int j = 0; j < data.GetLength(1); j++)
                {
                    printColor(data[i, j].ToString().PadLeft(2, ' '), color[ data[i, j]] );
                }
 
                Console.WriteLine();
            }
        }
        static void printColor(string s, ConsoleColor c)
        {
            var old = Console.ForegroundColor;
            Console.ForegroundColor = c;
            Console.Write(s);
            Console.ForegroundColor = old;
        }
    }
}


Добавлено через 45 секунд
Ответ вам был дан раньше, но вы почему то им не воспользовались.
0
20 / 19 / 4
Регистрация: 22.03.2018
Сообщений: 701
24.01.2019, 14:53  [ТС]
Спасибо но а как мне вывести
те единицы которые нашли максимальную площадь отдельно ?

0 0 0 0 1 1 0 0 0
1 0 1 0 0 0 0 0 0
1 1 1 0 0 1 0 0 0
1 1 1 1 1 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0

Которые нашли максимальную площадь ?
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1

0 0 0 0 1 1 0 0 0
1 0 1 0 0 0 0 0 0
1 1 1 0 0 1 0 0 0
1 1 1 1 1 0 0 0 0
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1

Добавлено через 14 секунд
maximka777, Спасибо но а как мне вывести
те единицы которые нашли максимальную площадь отдельно ?

0 0 0 0 1 1 0 0 0
1 0 1 0 0 0 0 0 0
1 1 1 0 0 1 0 0 0
1 1 1 1 1 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0

Которые нашли максимальную площадь ?
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1

0 0 0 0 1 1 0 0 0
1 0 1 0 0 0 0 0 0
1 1 1 0 0 1 0 0 0
1 1 1 1 1 0 0 0 0
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1

Добавлено через 25 минут
Нельзя что бы он закрашивал единицы

Добавлено через 16 секунд
Чёрным цветом

Добавлено через 23 минуты
Сделал
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace ConsoleApp10
{
    class Program
    {
        static void Main(string[] args)
        {
            int[,] a = {
               { 0,0,0,0,  1,1,0,0,0 },
               { 1,0,1,0,  0,0,0,0,0 },
               { 1,1,1,0,  0,1,0,0,0 },
               { 1,1,1,1,  1,0,0,0,0 },
 
               { 0,0,0,0,  0,0,0,0,0 },
               { 0,0,0,0,  0,0,0,0,0 },
               { 0,0,0,0,  0,0,0,0,0 },
               { 0,0,0,0,  0,0,0,0,0 }
 
            };
            print(a);
 
            Console.WriteLine();
 
            insert(a);
            Console.WriteLine();
 
            print(a);
            Console.ReadKey();
        }
        public static bool insert(int[,] a)
        {
            int maxSum = int.MinValue;
            int maxRowStart = -1;
            int maxColStart = -1;
            int maxRowEnd = -1;
            int maxColEnd = -1;
 
            for (int rowStart = 0; rowStart < a.GetLength(0); rowStart++)
            {
                for (int colStart = 0; colStart < a.GetLength(1); colStart++)
                {
                    for (int rowEnd = 0; rowEnd < a.GetLength(0); rowEnd++)
                    {
                        for (int colEnd = 0; colEnd < a.GetLength(1); colEnd++)
                        {
                            int sum = 0;
                            bool found = true;
                            for (int row = rowStart; row <= rowEnd; row++)
                            {
                                for (int col = colStart; col <= colEnd; col++)
                                {
                                    found &= a[row, col] != 1;
                                    sum += 1;
                                }
                            }
                            if (found && sum > maxSum)
                            {
                                maxSum = sum;
                                maxRowStart = rowStart;
                                maxColStart = colStart;
                                maxRowEnd = rowEnd;
                                maxColEnd = colEnd;
                            }
                        }
                    }
                }
            }
 
            if (maxRowStart < 0) return false;
 
            for (int row = maxRowStart; row <= maxRowEnd; row++)
            {
                for (int col = maxColStart; col <= maxColEnd; col++)
                {
                    a[row, col] = 1;
                    Console.Write(a[row , col] + " ");
                }
                Console.WriteLine(" ");
            }
 
            return true;
        }
        static void print(int[,] data)
        {
            var color = new[] { ConsoleColor.White, ConsoleColor.Green, ConsoleColor.Green };
 
            for (int i = 0; i < data.GetLength(0); i++)
            {
                for (int j = 0; j < data.GetLength(1); j++)
                {
                    printColor(data[i, j].ToString().PadLeft(2, ' '), color[data[i, j]]);
                }
 
                Console.WriteLine();
        }   }
        static void printColor(string s, ConsoleColor c)
        {
            var old = Console.ForegroundColor;
            Console.ForegroundColor = c;
            Console.Write(s);
            Console.ForegroundColor = old;
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.01.2019, 14:53
Помогаю со студенческими работами здесь

На какое максимальное количество квадратов можно разрезать прямоугольник
Короче есть кусок прямоугольный картона a*b. Дальше мы должны вырезать максимальные возможне КВАДРАТЫ. И вывести число сколько таких...

По заданной квадратной матрице построить вектор, элементы которого — максимумы элементов диагоналей
2.По заданной квадратной матрице 10х10 построить вектор длиной 19 элементы которого — максимумы элементов диагоналей,параллельных главной...

В заданной матрице найти максимальное значение
Помогите. В заданной матрице P (7,3) найти максимальное значение. Вывести исходную матрицу и найденное максимальное значение и его индексы...

Найти такое максимальное i в матрице, для которого выполняется заданное условие
Задана последовательность матриц {M}_{i}, имеющих размеры 30х30 и содержащие литеры.Функция Ф(М) определяет сумму всех кодов элементов...

Найти Количество нулей и едениц в матрице
Способ матрицы 4.Зада двумерный массив целых чисел А размером N на M, состоящий из нулей и едениц. Найти Количество нулей и едениц в этом...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru