Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
2 / 2 / 0
Регистрация: 02.01.2009
Сообщений: 14

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

01.11.2011, 18:30. Показов 1711. Ответов 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;
                        
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.11.2011, 18:30
Ответы с готовыми решениями:

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

Cоздать функцию, вычисляющую в квадратном целочисленном массиве сумму элементов k-го слоя ромба
создать функцию, вычисляющую в квадратном целочисленном массиве сумму элементов k-го слоя ромба. Первый слой ромба, это самый большой...

В целочисленном массиве M(n) найти максимальный элемент среди четных элементов массива и максимальный элемент
В целочисленном массиве M(n) найти максимальный элемент среди четных элементов массива и максимальный элемент среди нечетных элементов...

3
2 / 2 / 0
Регистрация: 02.01.2009
Сообщений: 14
02.11.2011, 19:46  [ТС]
Курсивом в матрце выделен первый слой ромба, жирным - второй и т.п.

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 / 0
Регистрация: 10.01.2016
Сообщений: 31
12.01.2016, 12:41
А у вас есть код программы на паскале?
0
Модератор
Эксперт CЭксперт С++
 Аватар для sourcerer
5288 / 2376 / 342
Регистрация: 20.02.2013
Сообщений: 5,773
Записей в блоге: 20
12.01.2016, 20:55
Нерион, теме пять лет. Раздел - "С++ для начинающих". Может было бы проще (и логичнее) в разделе по Паскалю Вам свой впорос задать?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.01.2016, 20:55
Помогаю со студенческими работами здесь

Найти максимальный элемент матрицы в области ромба
@@@ найти максимальный элемент матрицы среди(а;a;a;a;a) @@@ огромное спасибо!! @@@ Добавлено через 4 минуты найти среди (a;a;a;a)

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

В двумерном квадратном массиве найти произведение элементов.
В данном двумерном квадратном массиве найдите произведение элементов и минимум элементов, расположенных между главной и побочной...

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

Массив: Если в одномерном массиве из 10 элементов сумма четных элементов положительна, найти максимальный элемент...
Здравствуйте. Пожалуйста, сможете решить задачу по С++. Если в одномерном массиве из 10 элементов сумма четных элементов...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru