Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
1 / 1 / 0
Регистрация: 28.04.2019
Сообщений: 15

Эффективные алгоритмы (снова)

30.04.2019, 16:56. Показов 2715. Ответов 5

Студворк — интернет-сервис помощи студентам
Я в очередной раз борюсь с эффективными алгоритмами: Соревнования по игре «Тетрис-онлайн» проводятся по следующим правилам. Каждый участник регистрируется на сайте игры под определённым игровым именем. Имена участников не повторяются. Чемпионат проводится в течение определённого времени. В любой момент этого времени любой зарегистрированный участник может зайти на сайт чемпионата и начать зачётную игру. По окончании игры её результат (количество набранных очков) фиксируется и заносится в протокол. Участники имеют право играть несколько раз. Количество попыток одного участника не ограничивается. Окончательный результат участника определяется по одной игре, лучшей для данного участника. Более высокое место в соревнованиях занимает участник, показавший лучший результат. При равенстве результатов более высокое место занимает участник, раньше показавший лучший результат. В ходе соревнований заполняется протокол, каждая строка которого описывает одну игру и содержит результат участника и его игровое имя. Протокол формируется в реальном времени по ходу проведения чемпионата, поэтому строки в нём расположены в порядке проведения игр: чем раньше встречается строка в протоколе, тем раньше закончилась соответствующая этой строке игра. Напишите эффективную, в том числе по памяти, программу, которая по данным протокола определяет победителя и призёров. Гарантируется, что в чемпионате участвует не менее трёх игроков.

Входные данные
Первая строка содержит число N- общее количество строк протокола. Каждая из следующих N строк содержит записанные через пробел результат участника (целое неотрицательное число, не превышающее 100 миллионов) и игровое имя (имя не может содержать пробелов). Строки исходных данных соответствуют строкам протокола и расположены в том же порядке, что и в протоколе. Гарантируется, что количество участников соревнований не меньше 3.

Выходные данные
Программа должна вывести имена и результаты трёх лучших игроков по форме, приведённой ниже в примере


Вот мой код:
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
#include <iostream>
 
using namespace std;
struct golosa
{
    string player;
    int kol;
};
int main()
{
    string c;
    golosa a[100];
    for(int i = 0; i < 100; i++)
        a[i].kol = 0;
    int  n, cnt = 0, ind = 0, cnt2 = 0, sc = 0;
    //========================================================
    cin >> n;
 
    while (cnt < n)
    {
        cin >> sc;
        getline(cin, c);
        for(int i = 0; i < cnt2; i++)
        {
            if(a[i].player == c)
            {
                if(a[i].kol < sc) a[i].kol = sc;
                ind = 1;
            }
 
        }
        if(ind == 0)
        {
            a[cnt2].player = c;
           //cout << a[cnt2].player;
            a[cnt2].kol = sc;
            cnt2++;
        }
        cnt++;
        ind = 0;
    }
 
    //for(int i = 0; i < cnt2; i++)
      //  cout << i << " " << a[i].player  << " " << a[i].kol << "\n";
    for (int i = 1; i < cnt2; i++)
        {
            for (int j = 0; j < n - i; j++)
            {
                if (a[j].kol < a[j + 1].kol)
                {
                    golosa b = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = b;
                }
            }
        }
    for(int i = 0; i < 3; i++)
        cout << i + 1<< " place." << a[i].player  << "(" << a[i].kol << ")" << "\n";
    return 0;
}
Проверьте пожалуйста, где-то он вылетает. Никак не могу понять, где)
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.04.2019, 16:56
Ответы с готовыми решениями:

Задача на эффективные алгоритмы
Я пытаюсь решить задачу на эффективные алгоритмы: На вход программы подаются заглавные латинские буквы, ввод этих символов заканчивается...

Эффективные алгоритмы вставки и удаления элемента из массива
Необходимы два эти алгоритма. + Всем в карму

Снова хром, снова сапопроизвольно открывается, снова bkrfdf.xyz и казино
Здравствуйте! Собственно, проблема уже не новая, хотя, как показывают сообщения форума, за последние дни выскочившая у многих. Через...

5
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
30.04.2019, 17:15
foorgy, сортировка всего массива - не очень эффективно. Тут достаточно массива из трех элементов.
1
1 / 1 / 0
Регистрация: 28.04.2019
Сообщений: 15
30.04.2019, 17:17  [ТС]
zayats80888, я не так хорошо знакома с сортировками, в не могли бы прислать код сортировки на три элемента?
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
30.04.2019, 18:13
foorgy, Имхо, переменные cnt, cnt2 по ходу работы могут стать больше или равны 100. И - вылезание за память.
И уважаемый zayats80888 прав. Зачем нам поддерживать 100 записей? Нам нужно определить только первых трех. Достаточно поддерживать в актуальном состоянии массив из трех записей. По дороге обновляя их, если нужно.
Цитата Сообщение от foorgy Посмотреть сообщение
сортировки на три элемента?
Очевидно, тут речь идет не о сортировке, а именно о поддержке трех элементов.
1
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
30.04.2019, 18:24
Лучший ответ Сообщение было отмечено foorgy как решение

Решение

foorgy, особо не парился, но вроде работает, можно еще через очередь с приоритетом попробовать:
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
#include <iostream>
#include <fstream>
#include <string>
#include <algorithm>
 
struct player
{
    int score;
    std::string name;
    int num;
    player():score(-1), name(), num(0) {}
};
 
bool operator<(const player& lh, const player& rh)
{
    return
        (lh.score < rh.score) ||
        (lh.score == rh.score && lh.num > rh.num);
}
 
std::ostream& operator<<(std::ostream& os, const player& p)
{
    return os << p.name << ' ' << p.score;
}
 
int main()
{
    player winners[3]{};
    
    std::ifstream ifs{ "text.txt" };
    if (!ifs) return -1;
    
    player current;
    int num = 0;
    while (ifs >> current.score >> current.name)
    {
        current.num = num;
        int min_idx(0);
        int cur_idx(-1);
        for (int i = 0; i < 3; ++i)
        {
            if (winners[i].score < winners[min_idx].score)
                min_idx = i;
            if (winners[i].name == current.name)
            {
                cur_idx = i;
                break;
            }
        }
        if (cur_idx != -1 && current.score > winners[cur_idx].score)
            winners[cur_idx] = current;
        else
            if (current.score > winners[min_idx].score)
                winners[min_idx] = current;
        ++num;
    }
    std::sort(std::begin(winners), std::end(winners));
    for (int i = 2; i >= 0; --i)
        std::cout << winners[i] << std::endl;
}
1
1 / 1 / 0
Регистрация: 28.04.2019
Сообщений: 15
30.04.2019, 19:07  [ТС]
Спасибо вам за помощь, немного потыкалась и у самой получилось.
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
#include <iostream>
 
using namespace std;
struct tetris
{
    string player;
    int kol;
};
int main()
{
    string c;
    tetris a[4];
    for(int i = 0; i < 4; i++)
        {
            a[i].kol = -1;
            a[i].player = " ";
        }
    int  n, sc = 0;
    //========================================================
    cin >> n;
 
    while (0 < n)
    {
        cin >> sc >> c;
        int i, flag = 0, up = 0;
 
        for(i = 0; i < 3; i++)
        {
            if(a[i].player == c)
            {
                flag = 1;
                if(a[i].kol < sc)
                {
                    a[i].kol = sc;
                    up = 1;
                    break;
                }
            }
        }
        if(flag)
        {
            if(up)
            {
                if(a[2].kol > a[1].kol)
                {
                    tetris b = a[2];
                    a[2] = a[1];
                    a[1] = b;
                }
                if(a[1].kol > a[0].kol)
                {
                    tetris b = a[1];
                    a[1] = a[0];
                    a[0] = b;
                }
 
            }
        }
        else
        {
            a[3].kol = sc;
            a[3].player = c;
            for(int i = 3; i > 0; i--)
            {
                if(a[i].kol > a[i - 1].kol)
                {
                    tetris b = a[i];
                    a[i] = a[i - 1];
                    a[i - 1] = b;
                }
            }
        }
        n--;
    }
 
 
 
    for(int i = 0; i < 3; i++)
        cout << i + 1<< " place. " << a[i].player  << "(" << a[i].kol << ")" << "\n";
    return 0;
}
Добавлено через 48 секунд
zayats80888, наверно и это сработает, ещё раз спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.04.2019, 19:07
Помогаю со студенческими работами здесь

Эффективные гиперссылки из Excel?
Не раз замечал, что Яндекс кроме html-текста на странице индексирует еще и документы excel размещенные на сайте. Например прайс-листы....

Самые тихие и эффективные кулеры
Посоветуйте производителей, а лучше конкретные модели самых тихих и производительных кулеров на рынке продаж на сегодняшний день,...

Как сделать чтобы таймер дойдя до 0 стартовал снова и снова?
Здравствуйте :) Как сделать чтобы таймер дойдя до 0 стартовал снова и снова? TimerSec = 59; TimerMin = 6; for(int i = TimerSec;...

Самые эффективные средства для чистки
Подскажите пожалуйста самые эффективные средства для чистки микроволновки. Зависит ли выбор такого средства от внутреннего покрытия или они...

HP 625 снова и снова перезагружается в безопасный не заходит
Ребята помогите , проблема вот какая врубаю я ноут он доходит до заставки майкрософта и снова перезагружается в безопасный не заходит, ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru