Форум программистов, компьютерный форум CyberForum.ru

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

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

Найти слово, один и тот же символ в котором встречается максимальное число раз (в рамках всей строки) C++
C++ Найти слово, один и тот же символ в котором встречается максимальное число раз
Найти слово, один и тот же символ в котором встречается максимальное число раз (в рамках всей строки). C++
C++ Цифра, повторяющаяся максимальное количество раз
C++ Среди чисел массива, встречающихся минимальное число раз, найти максимальное
C++ Минимальный элемент, повторяющийся максимальное количество раз в массиве
C++ Сколько раз встречается максимальное число
В одномерном массиве найти элемент, повторяющийся максимальное число раз C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Геомеханик
 Аватар для Геомеханик
517 / 324 / 253
Регистрация: 26.06.2015
Сообщений: 738
01.07.2015, 18:42     Найти число, повторяющееся максимальное количество раз #2
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;
}
Результат работы кода
Liori
 Аватар для Liori
3 / 3 / 1
Регистрация: 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;
}
Yandex
Объявления
01.07.2015, 21:49     Найти число, повторяющееся максимальное количество раз
Ответ Создать тему
Опции темы

Текущее время: 04:13. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru