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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 15, средняя оценка - 4.73
RainInBrain
0 / 0 / 0
Регистрация: 16.02.2011
Сообщений: 6
#1

Найти максимальный четный элемент массива - C++

16.02.2011, 23:45. Просмотров 2069. Ответов 5
Метки нет (Все метки)

Здравствуйте! Если вам не сложно - напишите пожалуйста программу для нахождения максимального четного элемента массива на Си.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.02.2011, 23:45     Найти максимальный четный элемент массива
Посмотрите здесь:

Найти первый четный элемент одномерного массива C++
C++ Найти максимальный четный элемент массива
Найти максимальный элемент массива C++
Найти максимальный элемент массива C++
C++ Найти максимальный элемент массива и вывести последний четный элемент
C++ Все отрицательные элементы заданного массива L (11) разделить на максимальный элемент этого массива. Вывести максимальный элемент, начальный и преобра
C++ найти максимальный элемент массива x(15) . переставить местами этот максимальный элемент с индексом 4
Найти и удалить последний четный элемент динамического массива C++
Массивы: найти сумму элементов массива: индекс которых не делится на 4 или элемент четный C++
C++ Найти максимальный элемент массива и сумму элементов массива по условию
C++ Найти максимальный элемент массива
C++ Найти 1 положительный,1 отрицательный ,1 четный элемент массива

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Merlin666
96 / 96 / 10
Регистрация: 26.12.2010
Сообщений: 220
16.02.2011, 23:59     Найти максимальный четный элемент массива #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
void main()
{
    int p[100][100];
 
    int n,m;
 
    printf("Enter n: ");
    scanf("%d",&n);
 
    printf("Enter m: ");
    scanf("%d",&m);
 
    printf("Enter your massive: ");
    for (int i=0; i<n; i++)
        for (int j=0; j<m; j++)
            scanf("%d",&p[i][j]);
 
    bool flag=false;
    int max=p[0][0];
 
    for (int i=0; i<n; i++)
        for (int j=0; j<m; j++)
        {
            if ((max<=p[i][j])&&(p[i][j]%2==0))
            {
                flag=true;
                max=p[i][j];
            }
        }
 
    if (flag) printf("Max = %d",max);
    else printf("None..");
 
    scanf(" ");
 
}
RainInBrain
0 / 0 / 0
Регистрация: 16.02.2011
Сообщений: 6
17.02.2011, 00:03  [ТС]     Найти максимальный четный элемент массива #3
cпасибо большое теперь не отчислят ))
silent_1991
Эксперт С++
4956 / 3032 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
17.02.2011, 00:07     Найти максимальный четный элемент массива #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
#include <stdio.h>
 
int max_even_elem(int *, size_t);
 
int main(void)
{
    int arr[10] = {5, -2, 7, 20, 43, 12, 34, -44, 0, 10};
 
    printf("max elem = %d\n", max_even_elem(arr, 10));
 
    return 0;
}
 
int max_even_elem(int *arr, size_t size)
{
    int max = arr[0];
 
    for (size_t i = 1; i < size; ++i)
        if (arr[i] % 2 == 0 && arr[i] > max)
            max = arr[i];
 
    return max;
}
Добавлено через 55 секунд

Не по теме:

Эх, каждый раз ведь говорю себе "обнови страницу, не тупи" - и ведь всегда туплю и не обновляю!

Merlin666
96 / 96 / 10
Регистрация: 26.12.2010
Сообщений: 220
17.02.2011, 00:12     Найти максимальный четный элемент массива #5
Цитата Сообщение от silent_1991 Посмотреть сообщение
int max_even_elem(int *arr, size_t size)
{
* * int max = arr[0];
for (size_t i = 1; i < size; ++i)
* * * * if (arr[i] % 2 == 0 && arr[i] > max)
* * * * * * max = arr[i];
return max;
}
Небольшой недочет - если все элементы массива нечетные, то выдаст первый элемент, но он тоже нечетный..
silent_1991
Эксперт С++
4956 / 3032 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
17.02.2011, 00:22     Найти максимальный четный элемент массива #6
Merlin666, тогда так:

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
#include <stdio.h>
 
int max_even_elem(int *, size_t, int *);
 
int main(void)
{
    int arr[10] = {5, -2, 7, 20, 43, 12, 34, -44, 0, 10};
    int elem;
 
    if (max_even_elem(arr, 10, &elem) == 1)
        printf("max even elem = %d\n", elem);
 
    return 0;
}
 
int max_even_elem(int *arr, size_t size, int *elem)
{
    *elem = arr[0];
    int key = 0;
 
    for (size_t i = 1; i < size; ++i)
    {
        if (arr[i] % 2 == 0 && arr[i] > *elem)
        {
            *elem = arr[i];
            key = 1;
        }
    }
 
    return key;
}
Yandex
Объявления
17.02.2011, 00:22     Найти максимальный четный элемент массива
Ответ Создать тему
Опции темы

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