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

Timus Time limit exceeded (Bingo!)

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

Author24 — интернет-сервис помощи студентам
Здравствуйте. Второй день уже пытаюсь решить проблемы "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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.11.2019, 11:50
Ответы с готовыми решениями:

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

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

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

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

3
Эксперт .NET
17790 / 12941 / 3381
Регистрация: 17.09.2011
Сообщений: 21,215
16.11.2019, 11:53 2
Приведите текст задачи - ссылка ведет на страницу регистрации.
0
0 / 0 / 0
Регистрация: 06.04.2016
Сообщений: 4
16.11.2019, 11:55  [ТС] 3
Там нужно просто ввести имя, не нужно регистрироваться. Задача B. Задача довольно длинная, поэтому здесь текст не привожу
Прошу прощения, ссылка некорректная. http://trial.timus-offline.net/start.aspx
0
0 / 0 / 0
Регистрация: 06.04.2016
Сообщений: 4
17.11.2019, 11:26  [ТС] 4
Текст задачи и иллюстрация к ней + условия подзадач:
Миниатюры
Timus Time limit exceeded (Bingo!)   Timus Time limit exceeded (Bingo!)  
0
17.11.2019, 11:26
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.11.2019, 11:26
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru