С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 06.04.2016
Сообщений: 4

Timus Time limit exceeded (Bingo!)

16.11.2019, 11:50. Показов 1196. Ответов 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
Ответ Создать тему
Новые блоги и статьи
изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru