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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 5.00
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
#1

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

22.11.2009, 21:46. Просмотров 1091. Ответов 22
Метки нет (Все метки)

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


Что делаю: объявляю массив mas[9], через вложенный цикл ищу повторяющиеся элементы, записываю число повторений в друго массив (dop[9]) и вот тут проблема...
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 <conio.h>
 
using namespace std;
 
int main()
 
{
    int mas[9];
int dop[9];
int i,j,k;
 
cout<<"1.el.massiva=";cin>>mas[0];
cout<<"2.el.massiva=";cin>>mas[1];
cout<<"3.el.massiva=";cin>>mas[2];
cout<<"4.el.massiva=";cin>>mas[3];
cout<<"5.el.massiva=";cin>>mas[4];
cout<<"6.el.massiva=";cin>>mas[5];
cout<<"7.el.massiva=";cin>>mas[6];
cout<<"8.el.massiva=";cin>>mas[7];
cout<<"9.el.massiva=";cin>>mas[8];
cout<<"10.el.massiva=";cin>>mas[9];
 
for (i=0;i<=9;i++)
for (j=0;j<=9;j++)
 
{
k=0;
if (mas[i]==mas[j]) // может условие не то?  А то оно у меня сравнивает с теме же цифрами думал добавить, еще( && i!=j)-это что б с одинаковыми индексами не сравнивать???????
 
k=k+1;  //Короче к k присваивается 1, но оно так и наращивается
 
dop[i]=k;
 
cout<<i<<","<<j<<"="<<dop[i]<<"\n";
 
}
........................................................................................................................................
До этого не дошел пока.
Дальше буду искать максимально повторяющийся элемент, и выводить число...
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.11.2009, 21:46     Найти максимально повторяющееся число в массиве
Посмотрите здесь:

C++ Найти число последовательности, у которого количество одинаковых цифр максимально
C++ Найти число последовательности, у которого количество одинаковых цифр максимально
C++ В массиве целых чисел найти максимально длинную возрастающую последовательность
C++ Найти число на отрезке [x;y], произведение цифр которого максимально
C++ В массиве найти минимальный положительный и максимально отрицательный элемент и вычисляет их следующее значени
C++ В вещественном массиве найти число максимально близкое к заданному целому
C++ Найти в массиве точки, которые максимально удалены от начала координат
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
^Tecktonik_KiLLeR
 Аватар для ^Tecktonik_KiLLeR
1158 / 440 / 22
Регистрация: 23.06.2009
Сообщений: 6,219
Завершенные тесты: 1
22.11.2009, 22:19     Найти максимально повторяющееся число в массиве #2
1.помести код в теги для С++
2.в чем проблема?
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
22.11.2009, 22:28  [ТС]     Найти максимально повторяющееся число в массиве #3
Хотя бы правильно заполнить массив (dop[]), с повторениями:

Пример: Если я ввожу 1223456789

то число повторений в массиве dop[] должно быть примерно 0100000000

а она мне переполняет массив dop[] там у меня ни пойми что -8745433353 в каждой ячейки...

пробовал К "обнулять" . т.е

C++
1
2
3
4
5
6
7
k=0;// Вот здесь я выносил К т.е К у меня К наращивалась до 9, а если К внести в болк обратно то, то К у меня  обнуляется постоянно...
{
if (mas[i]==mas[j]) 
k=k+1;
dop[i]=k;
cout<<i<<","<<j<<"="<<dop[i]<<"\n";
}
trive
 Аватар для trive
4 / 4 / 1
Регистрация: 05.10.2009
Сообщений: 19
22.11.2009, 22:48     Найти максимально повторяющееся число в массиве #4
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Если я правильно понял условие
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
#include <iostream>
#include <conio.h>
 
using namespace std;
 
void main()
 
{
int mas[9];
int dop[9];
int i,j,k;
 
for(i=0;i<=9;i++)
{
 cout<<i+1<<".el.massiva=";
 cin>>mas[i];
}
for (i=0;i<=9;i++)
{
 k=0;
 for (j=0;j<=9;j++)
        {
         if ((mas[i]==mas[j])&&(i!=j))
         k++;
        }
 dop[i]=k;
}
int max=dop[0];
for(i=1;i<9;i++)
        if(max<dop[i])
                max=dop[i];
cout<<dop[i]; getch();
}
Это если вам понадобится дополнительный массив, если же он больше не требуется, то зачем он нужен?))
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
#include <iostream>
#include <conio.h>
 
using namespace std;
 
void main()
 
{
int mas[9];
int dop[9];
int i,j,k,max=0;
 
for(i=0;i<=9;i++)
{
 cout<<i+1<<".el.massiva=";
 cin>>mas[i];
}
for (i=0;i<=9;i++)
{
 k=0;
 for (j=0;j<=9;j++)
        {
         if ((mas[i]==mas[j])&&(i!=j))
         k++;
        }
 if (k>max) max=k;
}
cout<<max;
getch();
}
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
22.11.2009, 22:57  [ТС]     Найти максимально повторяющееся число в массиве #5
Я запустил:

Ввел : 1234516719 он вывел 0 не получилось!

dop[i] заполнился так

dop[i]
[0]=2
[1]=0
[2]=0
[3]=0
[4]=0
[5]=2
[6]=0
[7]=0
[8]=2

Добавлено через 1 минуту
Это конечно грамотно заполняется массив через цикл, я что то не догодался

for(i=0;i<=9;i++)
{
cout<<i+1<<".el.massiva=";
cin>>mas[i];
}
trive
 Аватар для trive
4 / 4 / 1
Регистрация: 05.10.2009
Сообщений: 19
22.11.2009, 22:59     Найти максимально повторяющееся число в массиве #6
Я не знаю как вы запускали, но у меня- работает...
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
22.11.2009, 23:02  [ТС]     Найти максимально повторяющееся число в массиве #7
Я запустил 1-й пример...
lolopolosko
 Аватар для lolopolosko
1352 / 310 / 5
Регистрация: 21.11.2009
Сообщений: 992
22.11.2009, 23:02     Найти максимально повторяющееся число в массиве #8
ForestG, задача trive правильна...вы просто чтото не то компилируете....
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
22.11.2009, 23:11  [ТС]     Найти максимально повторяющееся число в массиве #9
Согласен, сейчас переделаю...

Добавлено через 2 минуты
Переделал запустил в торой исходик...

Ввел числа:
1234112678

он вывел 2 а должен вывести число 1

т.к оно больше всех повторяется...

Добавлено через 4 минуты
}
if (k>max) max=k;
}
cout<<max;

Кстати помоему здесь ошибка, на выводе должно быть помоему mas[i], а не max- т.к max - это число повторений а не число в массиве

Добавлено через 49 секунд
Попробую переделать
trive
 Аватар для trive
4 / 4 / 1
Регистрация: 05.10.2009
Сообщений: 19
22.11.2009, 23:11     Найти максимально повторяющееся число в массиве #10
Вам выводить макс повторяющееся число или к-во раз, которое оно повторяется?
lolopolosko
 Аватар для lolopolosko
1352 / 310 / 5
Регистрация: 21.11.2009
Сообщений: 992
22.11.2009, 23:12     Найти максимально повторяющееся число в массиве #11
Сообщение было отмечено автором темы, экспертом или модератором как ответ
вот
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
#include <iostream.h>
#include <conio.h>
using namespace std;
 
int main()
 
{
int mas[9];
int dop[9];
int k,z,max;
 
for(int i=0;i<=9;i++){
        cout<<"["<<i<<"]>";
        cin>>mas[i];
        }
        
for(int i=0;i<=9;i++){k=0;
for(int j=0;j<=9;j++){if(mas[i]==mas[j])k=k+1; 
dop[i]=k;}}
max=0;
for(int i=0;i<=9;i++){if(dop[i]>max)max=dop[i];}
for(int i=0;i<=9;i++){if(dop[i]==max)z=i;}                       
 
 
cout<<"\n4islo "<<mas[z]<<" povtorivaetsa "<<max<<" raz";                          
getch();
return 0;
}
пробуйте....у мня выйшло...сам эту писал
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
22.11.2009, 23:12  [ТС]     Найти максимально повторяющееся число в массиве #12
По заданию максимально повторяющиеся число, а не число повторений...

Вводится массив из десяти чисел. Найти максимально повторяющееся число.
trive
 Аватар для trive
4 / 4 / 1
Регистрация: 05.10.2009
Сообщений: 19
22.11.2009, 23:14     Найти максимально повторяющееся число в массиве #13
Прошу прощение, невнимательно прочел
ЗЫ строку
C++
1
int dop[9];
можно убрать
lolopolosko
 Аватар для lolopolosko
1352 / 310 / 5
Регистрация: 21.11.2009
Сообщений: 992
22.11.2009, 23:15     Найти максимально повторяющееся число в массиве #14
Сообщение было отмечено автором темы, экспертом или модератором как ответ
если будете компилировать в высуал то getch и библиотеку конио советую убрать

вот так

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
#include <iostream.h>
 
using namespace std;
 
int main()
 
{
int mas[9];
int dop[9];
int k,z,max;
 
for(int i=0;i<=9;i++){
        cout<<"["<<i<<"]>";
        cin>>mas[i];
        }
        
for(int i=0;i<=9;i++){k=0;
for(int j=0;j<=9;j++){if(mas[i]==mas[j])k=k+1; 
dop[i]=k;}}
max=0;
for(int i=0;i<=9;i++){if(dop[i]>max)max=dop[i];}
for(int i=0;i<=9;i++){if(dop[i]==max)z=i;}                       
 
 
cout<<"\n4islo "<<mas[z]<<" povtorivaetsa "<<max<<" raz";                          
 
return 0;
}
lolopolosko
 Аватар для lolopolosko
1352 / 310 / 5
Регистрация: 21.11.2009
Сообщений: 992
22.11.2009, 23:19     Найти максимально повторяющееся число в массиве #15
+ рисунок чтобы посмотреть как выполняется
Миниатюры
Найти максимально повторяющееся число в массиве  
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
22.11.2009, 23:21  [ТС]     Найти максимально повторяющееся число в массиве #16
У меня Visual Studio 2005, откомментировал все нормально, только из библиотеки
убрал .h - ошибку выдал, .h - это же для С, а не для С++ Да ?

#include <iostream.h>


Все признателен, спасибо я над этой задачкой бился около 5-и дней Спасибо

Добавлено через 52 секунды
Я в шоке все работает
lolopolosko
 Аватар для lolopolosko
1352 / 310 / 5
Регистрация: 21.11.2009
Сообщений: 992
22.11.2009, 23:21     Найти максимально повторяющееся число в массиве #17
спасибо ниже меня говорится)))))
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
22.11.2009, 23:22  [ТС]     Найти максимально повторяющееся число в массиве #18
ну теперь буду еще пять дней сидеть код этот изучать
lolopolosko
 Аватар для lolopolosko
1352 / 310 / 5
Регистрация: 21.11.2009
Сообщений: 992
22.11.2009, 23:23     Найти максимально повторяющееся число в массиве #19
попробуй модефицировать его...я думаю его можно намного сократить..если хорошенько подумать)))))
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.11.2009, 23:25     Найти максимально повторяющееся число в массиве
Еще ссылки по теме:

Найти число, повторяющееся максимальное количество раз C++
C++ В массиве найти номер числа, максимально приближенное к заданному
C++ Массив: вывести число, повторяющееся наибольшее число раз.
C++ Найти число повторяющееся наибольшее количество раз
Строки: найти слово, в котором число различных символов максимально C++

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

Или воспользуйтесь поиском по форуму:
ForestG
 Аватар для ForestG
32 / 32 / 3
Регистрация: 21.11.2009
Сообщений: 201
22.11.2009, 23:25  [ТС]     Найти максимально повторяющееся число в массиве #20
Попробую

Добавлено через 31 секунду
bb
Yandex
Объявления
22.11.2009, 23:25     Найти максимально повторяющееся число в массиве
Ответ Создать тему
Опции темы

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