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

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

Войти
Регистрация
Восстановить пароль
 
Анютка
2 / 2 / 0
Регистрация: 02.01.2009
Сообщений: 14
#1

Максимальный элемент ромба элементов в квадратном массиве. Помогите найти ошибку. - C++

01.11.2011, 18:30. Просмотров 657. Ответов 3
Метки нет (Все метки)

Задание: Создать функцию, определяющую максимальный элемент k-го слоя среднего наибольшего ромба элементов в квадратном массиве matrix[n][n] (n – нечетное). Номер слоя k задать с консоли.

Программу написала, но вот проблема: не всегда правильно высчитывает максимальный элемент; заметила, что это связано, когда макс.элемент находится в последней диагонали ромба... Но никак не могу понять, в чем именно ошиблась.
Пожалуйста, помогите найти ошибку и исправить ее.

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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#include <stdio.h>
#include <conio.h>
#include <math.h>
 
int max_sloy_romb(int m, int c, int mass[c][c]);
void main()
 
{ 
    const int n=4;
    int massiv_min, massiv_max;
    int i,j,k,q,max;
    int massiv[n][n];   
    time_t t;
    srand((unsigned) time(&t));
    
printf("\n Vvedite min element massiva:");
scanf("%d", &massiv_min);
printf("\n Vvedite max element massiva:");
scanf("%d", &massiv_max);
printf("\n \n");
 
    for (i=0; i<=n; i++)
    {
        for (j=0; j<=n; j++)
        {
            q=massiv_max-massiv_min+1;
            massiv[i][j]=rand()%q+massiv_min;
            printf("%5d", massiv[i][j]);        
        }
    printf("\n");
    }
    
    printf("\n Vvedite nomer sloya romda:");
    scanf("%d", &k);        
    max=max_sloy_romb(k-1, n, massiv);
    printf("\n Max element v %d-m sloe romba = %d",k,max);
}
        
int max_sloy_romb(int m, int c, int mass[c][c])
{
    int i, j;
    int max_element=mass[m][c/2];
    for (i=m; i<(c/2); i++)
        {       
        for (j=(c/2); j>m; j--)
            {           
            if (mass[i][(c/2)-i+m]>max_element)
            max_element=mass[i][(c/2)-i+m];
            }
        }
        
        for (i=(c/2); i<c; i++)
            {           
            for (j=m; j<(c/2); j++)
                {
                if (mass[i][i-(c/2)+m]>max_element)
                max_element=mass[i][i-(c/2)+m];
                }
            } 
            
            for (i=(c-m); i>(c/2); i--)
                {               
                for (j=(c/2); j<(c-m); j++)
                    {
                    if (mass[i][c+(c/2)-i-m]>max_element)
                    max_element=mass[i][c+(c/2)-i-m];
                    }
                }
                
                for (i=(c/2); i>m; i--)
                    {           
                    for (j=(c-m); j>(c/2); j--)
                        {
                        if (mass[i][i+(c/2)-m]>max_element)
                        max_element=mass[i][i+(c/2)-m];                     
                        }                           
                    }
            
            
        return max_element;
                        
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.11.2011, 18:30
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Максимальный элемент ромба элементов в квадратном массиве. Помогите найти ошибку. (C++):

Классы. В массиве чисел размером 6х6 элементов найти максимальный элемент, минимальный элемент и их индексы - C++
В массиве чисел размером 6х6 элементов найти максимальный элемент, минимальный элемент и их индексы. ...

Дан массив целых чисел. Найти В этом массиве минимальный элемент т и максимальный элемент м. Вывести сумму элементов от минимального до максимального - C++
Дан массив целых чисел. Найти В этом массиве минимальный элемент т и максимальный элемент м. Вывести сумму элементов от минимального до...

Найти максимальный отрицательный элемент в массиве целочисленных элементов. - C++
Как переделать под эти данные. 13. Дан одномерный массив, состоящий из N целочисленных элементов. 13.1. Ввести массив с клавиатуры. ...

В массиве найти максимальный элемент среди положительных элементов массива - C++
:wall:В массиве X(N) найти максимальный элемент среди положительных элементов массива и минимальный среди отрицательных элементов.

В одномерном массиве найти максимальный элемент и сумму заданных элементов - C++
В одномерном массиве, которые состоит из N действительных элементов, вычислить: 1) Максимальный по модулю элемент массива 2) Сумму...

В массиве X(N) найти сумму абсолютных значений элементов и максимальный элемент по модулю - C++
В массиве X(N) найти сумму абсолютных значений элементов и максимальный элемент по модулю

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Анютка
2 / 2 / 0
Регистрация: 02.01.2009
Сообщений: 14
02.11.2011, 19:46  [ТС] #2
Курсивом в матрце выделен первый слой ромба, жирным - второй и т.п.

6 5 6 0 8
9 6 5 5 3
5 7 9 8 8
3 3 4 4 1
2 6 2 5 8
Нерион
0 / 0 / 0
Регистрация: 10.01.2016
Сообщений: 31
12.01.2016, 12:41 #3
А у вас есть код программы на паскале?
gru74ik
Модератор
Эксперт CЭксперт С++
4142 / 1768 / 197
Регистрация: 20.02.2013
Сообщений: 4,897
Записей в блоге: 21
12.01.2016, 20:55 #4
Нерион, теме пять лет. Раздел - "С++ для начинающих". Может было бы проще (и логичнее) в разделе по Паскалю Вам свой впорос задать?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.01.2016, 20:55
Привет! Вот еще темы с ответами:

В вещественном массиве найти максимальный элемент среди его отрицательных элементов - C++
всем привет помогите пожалуйста.Решить задачу: в вещественном массиве найти максимальный элемент среди его отрицательных элементов.

Найти максимальный элемент (его номер и значение) в массиве А из 100 элементов - C++
4. Найти максимальный элемент (его номер и значение) в массиве А из 100 элементов.

В целочисленном массиве из 10 элементов найти максимальный элемент и заменить все элементы, значения которых нечетные на полученное значение максималь - C++
В целочисленном массиве из 10 элементов найти максимальный элемент и заменить все элементы, значения которых нечетные на полученное...

В целочисленном массиве найти максимальный элемент среди четных и среди нечетных элементов - C++
В целочисленном массиве X(N) найти max1 - максимальный элемент среди четных элементов массива и max2 - максимальный элемент среди нечетных...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
12.01.2016, 20:55
Ответ Создать тему
Опции темы

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