0 / 0 / 0
Регистрация: 10.01.2020
Сообщений: 3
1

Нахождение максимального элемента вектора

10.01.2020, 21:59. Показов 14929. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание, которое я выполнял:"Создать файл из N целых чисел. Найти число, повторяющееся максимальное количество раз. Если таких чисел несколько, то все из них. Сохранить эти числа в другой файл и отсортировать. Все файлы до и после обработки вывести на печать."
Цикл по нахождению максимального элемента вектора veccount не работает, как надо. То изменяет максимум на меньшее число, то идет не по той ветке if-а. Просьба указать на ошибку или показать рабочий вариант.
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
#include <iostream>
#include <fstream>
#include <vector>
#include <ctime>
using namespace std;
int main() {
    setlocale(LC_ALL, "RUSSIAN");
    ofstream fin;
    ifstream fout;
    int n, randnum, max = 0, maxi, maxcount = 1;
    cin >> n;
    vector <int> veccount(n);
    vector <int> veckeep(n);
    srand(time(0));
    fin.open("Task.txt");
    if (!fin.is_open())
        cout << "NOT OPEN";
    for (int i = 0; i < n; i++)
    {
        randnum = rand() % 10;
        cout << randnum << endl;
        fin << randnum << " ";
    }
    cout << "_________";
    fin.close();
    fout.open("Task.txt");
    for (int i = 0; i < n; i++)
        fout >> veckeep[i];
    for (int i = 0; i < n; i++)
        for (int j = i + 1; j < n; j++)
            if (veckeep[j] == veckeep[i])
                veccount[i]++;
    for (int i = 0; i < n; i++) // Этот цикл работает не так
    {
        if (max < veccount[i])
        {
            max = veccount[i];
            maxi = i;
        }
        else if (max = veccount[i])
        {
            maxcount++;
        }
 
    }
    fout.close();
    fin.open("Answer.txt");
    if (maxcount == 1)
        fin << veckeep[maxi];
    else for (int i = 0; i < n; i++)
        if (veccount[i] = max)
        {
            cout << veckeep[i];
            fin << veckeep[i];
        }
    fin.close();
    cout << "Проверьте файл!";
    return 0;
}
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.01.2020, 21:59
Ответы с готовыми решениями:

Нахождение максимального элемента в массиве и его индекс (элемента)
Доброго времени суток. Вот исходный код поиска максимального элемента массива: ...

Поиск максимального элемента вектора
Написала программу поиска максимального элемента вектора, только теперь её надо переделать немного...

Нахождение максимального элемента
Друзья, вот незадача, код написан, а работает не верно. Голову сломал что не так, может кто увидит...

Определить четность максимального элемента вектора
1.Дан вектор X(N)Определить каким числом четным или не четным является номер максимального элемента...

5
653 / 466 / 183
Регистрация: 23.04.2019
Сообщений: 1,987
10.01.2020, 22:42 2
Лучший ответ Сообщение было отмечено Kareger как решение

Решение

Если используете вектора, зачем мозги занимать hello, world? используйте
C++
1
max_element(veccount.begin(), veccount.end())
Добавлено через 1 минуту
Оно вернёт указатель на максимальный элемент
Если вам нужен его порядковый номер в векторе используйте это
C++
1
distance(veccount.begin(), max_element(veccount.begin(), veccount.end()));
0
0 / 0 / 0
Регистрация: 10.01.2020
Сообщений: 3
10.01.2020, 23:05  [ТС] 3
C++
1
max_element(veccount.begin(), veccount.end())
Для использования этой функции нужна доп библиотека? У меня не получается присвоить переменной разадрессацию указателя
C++
1
max = max_element(veccount.begin(), veccount.end());
Что так,
C++
1
max = &max_element(veccount.begin(), veccount.end());
что так не выходит

Добавлено через 15 минут
С библиотекой вопрос понял, #include <algorithm>, а вот насчет присваивания значения переменной так и не разобрался.
0
Неэпический
17815 / 10586 / 2044
Регистрация: 27.09.2012
Сообщений: 26,627
Записей в блоге: 1
10.01.2020, 23:11 4
Цитата Сообщение от AndryS1 Посмотреть сообщение
Оно вернёт указатель на максимальный элемент
Итератор.

Цитата Сообщение от Kareger Посмотреть сообщение
У меня не получается присвоить переменной
C++
1
2
3
4
//Вектор не должен быть пустым!!!
auto it = max_element(veccount.begin(), veccount.end());
max = *it;
maxi = it - veccount.begin();
1
0 / 0 / 0
Регистрация: 10.01.2020
Сообщений: 3
10.01.2020, 23:19  [ТС] 5
Цитата Сообщение от Croessmah Посмотреть сообщение
Итератор.
Благодарю, с итератором все заработало, хоть до конца его и не понимаю. А в моем первом цикле:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
for (int i = 0; i < n; i++) // Этот цикл работает не так
    {
        if (max < veccount[i])
        {
            max = veccount[i];
            maxi = i;
        }
        else if (max = veccount[i]) // Вот тут не два равно
        {
            maxcount++;
        }
 
    }
За равно не уследил. После этого все вроде как работает нормально.
0
Неэпический
17815 / 10586 / 2044
Регистрация: 27.09.2012
Сообщений: 26,627
Записей в блоге: 1
10.01.2020, 23:21 6
Цитата Сообщение от Kareger Посмотреть сообщение
Благодарю, с итератором все заработало, хоть до конца его и не понимаю
http://amse.ru/courses/cpp2/2011_03_14.html
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.01.2020, 23:21
Помогаю со студенческими работами здесь

Нахождение максимального элемента в матрице
Нужно решить задачу и найти наибольший элемент. Подскажите, как сделать? НУЖНО РЕШИТЬ ЗАДАЧУ И...

Нахождение максимального элемента матрицы
Написать программу для вывода наибольшего элемента матрицы С=(Сi j), і=1,2,... ,n; j=1,2,... ,m....

Нахождение максимального элемента списка
Есть код: // ConsoleApplication1.cpp : Defines the entry point for the console application. // ...

Нахождение максимального элемента одномерного массива
написать программу которая использует функцию для нахождения максимального по модулю элемента...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru