Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
DEVILD_Roma
3 / 3 / 0
Регистрация: 09.10.2014
Сообщений: 101
Завершенные тесты: 1
#1

Определить наибольшее число в массиве - C++

05.01.2016, 18:34. Просмотров 306. Ответов 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
34
35
36
37
38
39
40
41
42
#include<iostream>
#include<cstdlib>
using namespace std;
int main()
{
    cout<<"8 laba\n"<<endl;
    
    int N;
    int i=0;
    int j=0;
    int y=0;
     
    cout<<"Zadaite razmer masyvu ";
    cin>>N;
    cout<<endl;
    
    int a[N];
    int max=a[0];
    
    while(i < N){
        cout<<"a["<<j++<<"]"<<">>";
        cin>>a[i++];
    }
    
    for(int k=0;k < N;++k){
        if(a[k]>max){
            max = a[k];
        }   
    }
    
    cout<<endl<<"Max Chislo "<<max<<endl;
 
    for(i=0;i < N;i++){
        if(max==a[i]){
        y++;    
        }
    }   
    cout<<endl<<"Kolichestvo Vhojdenii "<<y<<endl;
    
    system("pause");
    return 0;
}
Но где то есть ошибка , суть ошибки в том что при вводе "0"(нуля) как одного из элемента массива(например размер массива 5 , 4 элемента 0 , а 5-ый 1) программа выдаёт что "0" наибольшее число,это первая проблема.Вторая в том что если ввести размер массива 3 , а элементы соответственно 3,3,2 (к примеру)- программа говорит что наибольшее число 8 , хоть его там нету.Заранее спасибо.
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.01.2016, 18:34
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Определить наибольшее число в массиве (C++):

Определить, какой из элементов повторяется в массиве наибольшее число раз - C++
Есть задание, но решить не могу, точнее не могу как задали. Можно задачу сделать с использование вложенного цикла, можно и без. Но вот до...

Наибольшее и наименьшее число в массиве. - C++
БИЛЕТ №17 3. Напишите программу, которая находит в массиве целых чисел наибольшее и наименьшее число и меняет их местами. Размер...

Поиск в массиве числа, встречающегося наибольшее число раз. - C++
задание такого: программа должна находить значение встречаещееся в массиве наибольшее число раз. если кто может помоч,буду очень...

Найти в массиве наибольшее число подряд идущих одинаковых элементов - C++
#include&lt;stdio.h&gt; #include&lt;stdlib.h&gt; #include &lt;iostream&gt; #include&lt;conio.h&gt; #include&lt;math.h&gt; //#define size 10 using namespace...

Найти в массиве наибольшее число подряд идущих одина*ковых элементов. - C++
Народ надо решить задачку...на простом СИ! Кто поможет буду благодарен... Найти в массиве наибольшее число подряд идущих одина*ковых...

Найти, какое значение встречается в данном массиве наибольшее число раз - C++
я ток что в универ поступил)) раньше с си++ ничего общего не имел)) и попал в очень сильную группу по программированию.. учительница очень...

4
Nosey
1349 / 400 / 107
Регистрация: 22.10.2014
Сообщений: 863
Завершенные тесты: 2
05.01.2016, 18:41 #2
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
DEVILD_Roma,

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
#include<iostream>
#include<cstdlib>
using namespace std;
int main()
{
    cout<<"8 laba\n"<<endl;
    
    int N;
    int i=0;
    int j=0;
    int y=0;
     
    cout<<"Zadaite rozmir masyvu ";
    cin>>N;
    cout<<endl;
    
// вообще так вот объяявлять массив нельзя, студия конечно позволяет, но нельзя.
// Если интересно нужно так
// int *a = new int[N];
// тогда в конце программы добавить : 
// delete[] a;
    int a[N];
// В этот момент в массиве у вас хранится неизвестно что, вы его ещё не заполнили, поэтому максимальное значение инииализируется мусором. (несуществующая 8)
    int max=a[0];
    
// заполнили массив.
    while(i < N){
        cout<<"a["<<j++<<"]"<<">>";
        cin>>a[i++];
    }
// сюда перенести инициализацию максимального значения.
    
    for(int k=0;k < N;++k){
        if(a[k]>max){
            max = a[k];
        }   
    }
    
    cout<<endl<<"Max Chislo "<<max<<endl;
 
    for(i=0;i < N;i++){
        if(max==a[i]){
        y++;    
        }
    }   
    cout<<endl<<"Kilkist\' Vhodjen\' "<<y<<endl;
    // сюда в случае изменения массива дописать удаление его delete[] a;
    system("pause");
    return 0;
}
1
nekitos911
0 / 0 / 0
Регистрация: 04.01.2016
Сообщений: 7
05.01.2016, 18:46 #3
Нельзя так массив задавать int a[N];
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
#include<iostream>
#include<cstdlib>
using namespace std;
int main()
{
    cout<<"8 laba\n"<<endl;
    
    int N;
    int i=0;
    int j=0;
    int y=0;
     
    cout<<"Zadaite rozmer masyvu ";
    cin>>N;
    cout<<endl;
    
    int *a=new int[N];
    int max=a[0];
    
    while(i < N){
        cout<<"a["<<j++<<"]"<<">>";
        cin>>a[i++];
    }
    
    for(int k=0;k < N;++k){
        if(a[k]>max){
            max = a[k];
        }   
    }
    
    cout<<endl<<"Max Chislo "<<max<<endl;
 
    for(i=0;i < N;i++){
        if(max==a[i]){
        y++;    
        }
    }   
    cout<<endl<<"Kolichestvo Vhojdenii "<<y<<endl;
    delete[] a;
    system("pause");
    return 0;
}
0
DEVILD_Roma
3 / 3 / 0
Регистрация: 09.10.2014
Сообщений: 101
Завершенные тесты: 1
05.01.2016, 18:48  [ТС] #4
Про инициализацию знаю.Но компилятор пропускает , в начале писал как Вы , но потом удалил. Переместил инициализацию максимального значения-помогло спасибо!
0
GbaLog-
Любитель чаепитий
3030 / 1398 / 337
Регистрация: 24.08.2014
Сообщений: 4,966
Записей в блоге: 1
Завершенные тесты: 2
05.01.2016, 19:06 #5
nekitos911,
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<cstdlib> // это тут вообще зачем?
#include <conio.h>
using namespace std;
int main()
{
    cout<<"8 laba\n"<<endl;
    int N;
    cout<<"Zadaite rozmer masyvu ";
    cin>>N;
    cout<<endl;
    int *a=new int[N];
    int max=0;
    for( int i = 0; i < N; i++ )
        cout<<"a["<<i<<"]"<<">>";
        cin>>a[i];
        if( a[max] < a[i] ) max = i;
    }
    cout<<endl<<"Max Chislo "<<a[max]<<endl;
    int count = 0;
    for(int i=0;i < N;i++){
        if(a[max]==a[i]){
        count++;    
        }
    }   
    cout<<endl<<"Kolichestvo Vhojdenii "<<count<<endl;
    delete[] a;
    getch();
    return 0;
}
0
05.01.2016, 19:06
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.01.2016, 19:06
Привет! Вот еще темы с ответами:

В массиве объектов класса найти фамилию сборщика, собравшего наибольшее число изделий - C++
Вообщем вот условие. Создать класс, содержащий сведения о количестве изделий, собранный сборщиками цеха за неделю. Класс должен содержать...

Определить наибольшее количество одинаковых элементов в вещественнозначном массиве a(n) - C++
Определить наибольшее количество одинаковых элементов в вещественнозначном массиве a(n)

Составить программу, которая подсчитывает, наибольшее число отрицательных идущих подряд в массиве чисел - C++
Добрый день,я составил программу по такому условию :&quot;Дан одномерный массив А, состоящий из N целых чисел. Составить программу, которая...

Определить наибольшее количество подряд идущих нулей в целочисленном массиве - C++
Здравствуйте! Задание: Дан целочисленный массив A. Определить наибольшее количество подряд идущих нулей. написала код, но он мне в...


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

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

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