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

Найти наиболее повторяющийся элемент в списке. Если таких элементов несколько, вывести все

29.04.2021, 17:43. Показов 5091. Ответов 0
Метки с++ (Все метки)

Студворк — интернет-сервис помощи студентам
В списке могут быть слова, цифры и знаки препинания. Код привожу ниже. Есть 2 проблемы: 1)не понимаю как сделать, что бы программа выводила несколько чисел. Например для списка 353535 программа должна выводить и 5 и 3. 2) для списка 353535 программа выводит число повторений тройки - 4, хотя должно быть 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
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
#include <iostream>
#include <iterator>
 
using namespace std;
 
struct Node {
    string val;
    Node* next;
 
    Node(string _val) : val(_val), next(nullptr) {}
};
 
struct list {
    Node* first;
    Node* last;
 
    list() : first(nullptr), last(nullptr) {}
 
    bool is_empty() { //проверка на наличие узлов в списке
        return first == nullptr;
    }
 
    void push_back(string _val) { // добавление элемента в конец списка
        Node* p = new Node(_val);
        if (is_empty()) {
            first = p;
            last = p;
            return;
        }
        last->next = p;
        last = p;
    }
 
    void print() { // вывод списка
        if (is_empty()) return;
        Node* p = first;
        while (p) {
            cout << p->val << " ";
            p = p->next;
        }
        cout << endl;
    }
 
    Node* operator[] (const int index) { //функция обращения к узлу по индексу
        if (is_empty()) return nullptr;
        Node* p = first;
        for (int i = 0; i < index; i++) {
            p = p->next;
            if (!p) return nullptr;
        }
        return p;
    }
};
 
int main()
{
    setlocale(LC_ALL, "Rus");
 
    int n, i ,j, max=0,new_max=0, index=0, new_new_max=0;
    string element;
 
    list l;
 
    cout << "Введите длину списка: ";
    cin >> n;
 
    cout << "Введите содержимое списка: ";
    for (int i = 0; i < n; i++)
    {
        cin >> element;
        l.push_back(element);
    }
 
    l.print();
    
    for (i = 0; i < n; i++) {
        for (j = 0; j < n; j++) {
            if ((l[i]->val == l[j]->val)&&(i!=j)) {
                max=max+1;
                if (max > new_max) {
                    new_max = max;
                    index = j;
                    max = 0;
                }
                
            }
        }
   }
 
   cout << "наиболее повторяющийся элемент:  "<<l[index]->val<< endl;
   cout << "кол-во повторений:  " << new_max;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.04.2021, 17:43
Ответы с готовыми решениями:

Вывести на экран наиболее часто встречающийся элемент . Если таких элементов несколько , то вывести все.
Дан символьный массив . Вывести на экран наиболее часто встречающийся элемент . Если таких элементов несколько , то вывести все. ( в данной...

Найти в массиве элемент с заданным значением; если таких элементов несколько, вывести индекс последнего из них
доброй ночи! Дан массив a. Элементы массива отсортированы в порядке возрастания. Используя метод двоичного поиска, найти в массиве...

Найти координаты точки наиболее удалённой от начала координат. Если таких точек несколько, вывести первую найденную
Прошу прощения. Тема закрыта (модератор, удалите) Сам нашел ошибку. :)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.04.2021, 17:43
Помогаю со студенческими работами здесь

В массиве целых чисел с количеством элементов n найти наиболее часто встречающееся число. Если таких чисел несколько, то
В массиве целых чисел с количеством элементов n найти наиболее часто встречающееся число. Если таких чисел несколько, то определить...

Определить наиболее часто встречающуюся оценку, если таких несколько, напечатать их все
помогите пожалуйста решить . 1.ввести и напечатать матрицу А(М,М) натуральных чисел. Среди элементов главной диагонали и выше нее; найти...

В массиве целых чисел с количеством элементов n найти наиболее встречающееся число. Если таких чисел несколько, то определить наименьший из них
В массиве целых чисел с количеством элементов n найти наиболее встречающееся число. Если таких чисел несколько, то определить наименьший из...

Найти элемент массива ближайший к заданному числу. Если таких чисел несколько, вывести наименьшее из них
Если с основным условием я справился, то с уточнением не могу. Вышло это: #include &lt;iostream&gt; #include...

Найти минимальный положительный элемент под главной диагональю. Если таких элементов несколько, выбрать первый
Найти минимальный положительный элемент под главной диагональю. Если таких элементов несколько, выбрать первый Не получается выбрать...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru