Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
Sergunchik228
0 / 0 / 0
Регистрация: 08.01.2015
Сообщений: 15
1

Найти число, повторяющееся максимальное количество раз

01.07.2015, 17:04. Просмотров 1425. Ответов 2
Метки нет (Все метки)

Прошу помощи. Болел - ничего не понял. Скоро экзамен, а я ничего не понимаю в С++. Дали примерные задачи, а я не понимаю как решать.
Вот задания: (помогите кто с каким может, только не просто решить, а с объяснениями) Зарание спасибо!
5. В целочисленном массиве A[n] найти число, повторяющееся максимальное количество раз. Если таких чисел несколько, то одно из них [5].
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.07.2015, 17:04
Ответы с готовыми решениями:

Найти число повторяющееся наибольшее количество раз
Есть массив в котором, нужно найти число повторяющееся наибольшее количество...

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

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

Среди чисел массива, встречающихся минимальное число раз, найти максимальное
Дан массив А из N элементов (0<N<1000;0<A<10000). Среди чисел массива,...

Найти слово, один и тот же символ в котором встречается максимальное число раз
длина входной строки не превосходит 300 символов, она вводится с консоли. Вам...

2
Геомеханик
792 / 597 / 939
Регистрация: 26.06.2015
Сообщений: 1,409
01.07.2015, 18:42 2
Лучший ответ Сообщение было отмечено Sergunchik228 как решение

Решение

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
#include <iostream>
#include <algorithm>
#include <cstddef>
 
 
int max_rep(int* f, int* l){
    int n = *f, *p;
    ptrdiff_t d, k = 0;
 
    //сортируем по-возрастанию
    std::sort(f, l);
 
    //далее пройдёмся по массиву
    while(f != l){
        p = f + 1;
 
        //подсчитываем повторы
        while((p != l) && (*p == *f))
            ++p;
 
        if((d = ptrdiff_t(p - f)) > k){
            k = d;
            n = *f;
        }
        f = p;
    }
    return n;
}
 
 
int main(void){
    int A[] = { 2, 3, 2, 1, 2, 1, 3, 2, 1 };
    int N   = sizeof(A)/sizeof(A[0]);
 
    std::cout << "max rep: " << max_rep(A, A + N) << std::endl;
    return 0;
}
Результат работы кода
0
Liori
4 / 4 / 5
Регистрация: 30.08.2012
Сообщений: 155
01.07.2015, 21:49 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
#include "stdafx.h"
#include <iostream>
#include <vector>
using namespace std;
 
int main(int argc, _TCHAR* argv[])
{
    int N, count=0, maxCount=0, maxNumber;  // кол-во элементов в массиве, счётчик с максимальным кол-вом, счётчик, максимальное значение
    cout << "Enter the number of elements in array: ";
    cin >> N; // размер массива
    vector<int> A(N); // создаем массив
 
    cout << "Enter the elements in array: " << endl;
    for (int i = 0; i < A.size(); i++)
        cin >> A[i]; //заполняем массив
 
    cout << "There is your array: " << endl;
    for (int i = 0; i < A.size(); i++)
        cout << A[i] << " "; // вывод массива
 
    for (int i = 0; i < A.size(); i++) 
    {
        for (int j = 0; j < A.size(); j++)
        {
            if (A[i] == A[j]) 
                count++; // к счётчику прибавляем 1, если в массива есть 2 одинаковых элемента
        }
        if (count > maxCount) // если счётчик больше счётчика с максимальным значением
        {
            maxCount = count; // счётчиком с максимальным значением становится данный счётчик
            maxNumber = A[i]; // запоминаем само максмаьное значение
            count = 0; // счётчик обнуляем
        }
    }
 
    cout << "\nMax number is " << maxNumber << endl; // выводим максимальное значение
    system("pause");
    return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.07.2015, 21:49

Найти слово, один и тот же символ в котором встречается максимальное число раз (в рамках всей строки)
состоит из слов, разделенных одним или несколькими пробелами. Найти слово, ...

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

Найти максимально повторяющееся число в массиве
Вводится массив из десяти чисел. Найти максимально повторяющееся число. ...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru