0 / 0 / 0
Регистрация: 06.04.2016
Сообщений: 4

Timus Time limit exceeded (Bingo!)

16.11.2019, 11:50. Показов 1253. Ответов 3

Студворк — интернет-сервис помощи студентам
Здравствуйте. Второй день уже пытаюсь решить проблемы "Timus, C#, Time limit exceeded", у меня не проходит вторую подзадачу(21 выдаёт ошибку времени выполнения). Буду очень признателен, если знающие люди подскажут мне решение по оптимизации или скажут, что я делаю не так. Сама задача из пробной олимпиады и называется "Bingo!"(Задача B). Сама пробная олимпиада: http://trial.timus-offline.net/schedule.aspx

Код моего решения этой задачи:
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
using System;
using System.Linq;
 
namespace Bingo
{
    class Program
    {
        public static int[,] table;
        public static int n;
        public static int m;
        public static int q;
        public static int k;
        public static int answer;
        public static int HMax;
        public static int VMax;
        static void Main(string[] args)
        {
            answer = 1;
            var nmqk = Console.ReadLine().Split();
            m = int.Parse(nmqk[0]);
            n = int.Parse(nmqk[1]);
            q = int.Parse(nmqk[2]);
            k = int.Parse(nmqk[3]);
            table = new int[n, m];
            for (int i = 0; i <= m - 1; i++)
            {
                var fst = Console.ReadLine().Split();
                for (int j = 0; j <= fst.Count() - 1; j++)
                {
                    table[j, i] = int.Parse(fst[j]);
                }
            }
            for (int w = 0; w <= q - 1; w++)
            {
                var ftsd = Console.ReadLine().Split();
                if (answer != 0)
                {
                    int ft = int.Parse(ftsd[0]);
                    int sd = int.Parse(ftsd[1]);
                    table[sd - 1, ft - 1] = 0;
                    CheckHorizontal(out HMax);
                    CheckVertical(out VMax);
                    answer = Math.Min(HMax, VMax);
                }
                Console.WriteLine(answer);
            }
            Console.Read();
        }
 
        static void CheckHorizontal(out int HMax)
        {
            HMax = k + 1;
            int jmax;
            int count = 0;
            for (int i = 0; i <= n - 1; i++)
            {
                count = 0;
                jmax = 0;
                for (int j = 0; j <= m - 1; j++)
                {
                    if (table[i, j] == 0)
                        count += 1;
                    if (table[i, j] > jmax)
                        jmax = table[i, j];
                }
                if (HMax == 0)
                    HMax = k + 1;
                if (count == m)
                {
                    if ((n == 2 && m == 1) || (n == 1 && m == 2))
                        continue;
                    HMax = 0;
                    return;
                }
                if (HMax > jmax)
                    HMax = jmax;
            }
        }
 
        static void CheckVertical(out int VMax)
        {
            if (answer == 0)
            {
                VMax = 0;
                return;
            }
            VMax = k + 1;
            int jmax;
            int count = 0;
            for (int i = 0; i <= m - 1; i++)
            {
                count = 0;
                jmax = 0;
                for (int j = 0; j <= n - 1; j++)
                {
                    if (table[j, i] == 0)
                        count += 1;
                    if (table[j, i] > jmax)
                        jmax = table[j, i];
                }
                if (VMax == 0)
                    VMax = k + 1;
                if (count == n)
                {
                    if ((n == 2 && m == 1) || (n == 1 && m == 2))
                        continue;
                    VMax = 0;
                    return;
                }
                if (VMax > jmax)
                    VMax = jmax;
            }
        }
    }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.11.2019, 11:50
Ответы с готовыми решениями:

Acm.timus.ru Time limit exceeded
Добрый день. Сама задача http://acm.timus.ru/problem.aspx?space=1&amp;num=1021 и мое решение: using System; using System.Linq; ...

Глюк при UpLoad'e файлов: Permission denied или The maximum amount of time for a script to execute was exceeded.
Подскажите, при каких ситуациях могут возникать ошибки Microsoft VBScript runtime error '800a0046' Permission denied или Active...

Time limit exceeded
Добрый день. Программа - бинарный поиск правой границы в упорядоченном множестве фраз. Возникает ошибка в компиляторе на сайте: &quot;time...

3
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
16.11.2019, 11:53
Приведите текст задачи - ссылка ведет на страницу регистрации.
0
0 / 0 / 0
Регистрация: 06.04.2016
Сообщений: 4
16.11.2019, 11:55  [ТС]
Там нужно просто ввести имя, не нужно регистрироваться. Задача B. Задача довольно длинная, поэтому здесь текст не привожу
Прошу прощения, ссылка некорректная. http://trial.timus-offline.net/start.aspx
0
0 / 0 / 0
Регистрация: 06.04.2016
Сообщений: 4
17.11.2019, 11:26  [ТС]
Текст задачи и иллюстрация к ней + условия подзадач:
Миниатюры
Timus Time limit exceeded (Bingo!)   Timus Time limit exceeded (Bingo!)  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.11.2019, 11:26
Помогаю со студенческими работами здесь

Time limit exceeded
Решаю задачки на одном сайте, там есть онлайн компилятор. Моя VS справляется, но компилятор с сайта говорит Time limit exceeded. Т.к....

Time limit exceeded
http://acm.timus.ru/problem.aspx?space=1&amp;num=1196 Уже все перепробовал, и всегда возникает ошибка &quot;Time limit exceeded&quot; на...

Матрица инцидентности = Time-limit exceeded
Как переделать программу, чтобы время ее выполнения было &lt;0.250 sec? #include &lt;iostream&gt; using namespace std; int main() { long...

Количество делителей - Time-limit exceeded >1.000
Нужно определить, сколько делителей имеет данное натуральное число? Входные данные: В одной строке дано натуральное число n (10^6...

Посмотрела в логи - а там execution time limit exceeded by agent
Добрый день Есть много разных агентов, но, если проанализировать логи, то десяток раз за день возникает в логах такое сообщение, что...


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

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

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru