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

Преобразование двумерной матрицы

18.05.2015, 17:15. Показов 1285. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В двумерном массивеb[n][m] найдите 4 последовательных элемента сумма которых максимальна.Обход начать с элемента [0][0] по часовой стрелке.
Когда преобразую двумерный массив в одномерный выбиваются некоторые элементы двумерного массива.Подскажите в чем проблема.
#include <cstdlib>
#include <iostream>
using namespace std;
int mas[5][6];
int b[30];
int i, j, l, m, n, n1,n2;
int k = 0;
void spi(int m)
{
for (j = m; j < n1 - m; j++)
{
b[k] = mas[m][j];
k ++;
}
for(i = m; i < n2 - m; i++)
{
b[k] = mas[i][n2 - m];
k ++;
}
for (j = n1 - m; j > m ; j--)
{
b[k] = mas[n1 - m][j];
k ++;
}
for (i = n2 - m; i > m ; i--)
{
b[k] = mas[i][m];
k ++;
}
}
int main()
{
int max=(b[0]+b[1]+b[2]+b[3]);
int step=4;
int pos=0;
int n=5;
int p=6;
n1 = n - 1;
n2 = p - 1;
cout<<"DVUMERNIY MASSIV:"<<endl;
for (i = 0; i < n; i++)
for (j = 0; j < p; j++)
mas[i][j] = rand()% 9;
for (i = 0; i < n; i++)
{
for (j = 0; j < p; j++)
cout << mas [i][j] ;
cout << "\n";
}
for(m = 0; m < n / 2; m++ )
{
for(m = 0; m < p / 2; m++ )
spi(m);
if((n%2 == 1)and(p%2 == 1)) b[n * p - 1] = mas[(n1)/2][(n2)/2];
cout << "\n";
cout<<"PREOBRAZOVANNIY MASSIV:"<<endl;
for (i = 0; i < n * p; i++)
{
cout << b[i]<<" ";
}
cout <<"\n";
cout <<endl;
cout<<"SUMMI ELEMENTOV:";
while(pos<=(30-step))
{
int sum=0;
sum=b[pos]+b[pos+1]+b[pos+2]+b[pos+3];
if(max<sum) max=sum;
cout << sum << " ";
pos++;
}
cout <<"MAX SUMMA:"<< max << endl;
return 0;
}
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.05.2015, 17:15
Ответы с готовыми решениями:

Диагональ двумерной матрицы
Привет всем! На сегодняшний день уже второй раз обращаюсь и мне очень неловко. Но и иначе никак. Задача: Дана матрица С. Вычислить и...

Функции и модули двумерной матрицы
Доброго всем дня. Дорогие пользователи форумом, пожалуйста помогите,завтра сдавать зачет по С++ а у меня 2 лабы еще не готовы. Вот...

Волновой алгоритм для двумерной матрицы
Подскажите пожалуйста как реализовать правильно(и желательно быстро) потому что, нужно будет считать для 4х объектов. Вот код который я...

2
 Аватар для Solitaire Raven
36 / 36 / 47
Регистрация: 20.04.2015
Сообщений: 198
18.05.2015, 17:19
Лучший ответ Сообщение было отмечено pro322 как решение

Решение

За вас сделал

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
#include <cstdlib>
#include <iostream>
using namespace std;
int mas[5][6];
int b[30];
int i, j, l, m, n, n1,n2;
int k = 0;
void spi(int m)
{
for (j = m; j < n1 - m; j++)
{
b[k] = mas[m][j];
k ++;
}
for(i = m; i < n2 - m; i++)
{
b[k] = mas[i][n2 - m];
k ++;
}
for (j = n1 - m; j > m ; j--)
{
b[k] = mas[n1 - m][j];
k ++;
}
for (i = n2 - m; i > m ; i--)
{
b[k] = mas[i][m];
k ++;
}
}
int main()
{
int max=(b[0]+b[1]+b[2]+b[3]);
int step=4;
int pos=0;
int n=5;
int p=6;
n1 = n - 1;
n2 = p - 1;
cout<<"DVUMERNIY MASSIV:"<<endl;
for (i = 0; i < n; i++)
for (j = 0; j < p; j++)
mas[i][j] = rand()% 9;
for (i = 0; i < n; i++)
{
for (j = 0; j < p; j++)
cout << mas [i][j] ;
cout << "\n";
}
for(m = 0; m < n / 2; m++ )
{
for(m = 0; m < p / 2; m++ )
spi(m);
if((n%2 == 1)and(p%2 == 1)) b[n * p - 1] = mas[(n1)/2][(n2)/2];
cout << "\n";
cout<<"PREOBRAZOVANNIY MASSIV:"<<endl;
for (i = 0; i < n * p; i++)
{
cout << b[i]<<" ";
}
cout <<"\n";
cout <<endl;
cout<<"SUMMI ELEMENTOV:";
while(pos<=(30-step))
{
int sum=0;
sum=b[pos]+b[pos+1]+b[pos+2]+b[pos+3];
if(max<sum) max=sum;
cout << sum << " ";
pos++;
}
cout <<"MAX SUMMA:"<< max << endl;
return 0;
}
 
}
0
0 / 0 / 0
Регистрация: 20.04.2015
Сообщений: 47
18.05.2015, 21:09  [ТС]
upp
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.05.2015, 21:09
Помогаю со студенческими работами здесь

Считывание двумерной матрицы из текстового файла
Здравствуйте. Есть задача: из входного текстового файла считать и вывести на экран вещественную матрицу, к примеру, 4х5. Как сделать...

Найти минимальные элементы в столбцах двумерной матрицы
С клавиатуры вводится двузмерная матрица ( не более 5×5), после чего делается ее контрольный вывод.Переписать минимальные элементы всех...

Посчитать сумму четных элементов двумерной матрицы
Посчитать сумму четных элементов двумерной матрицы МхN сформировать матрицу из случайных чисел и вывести на экран

[C++] есть ли в столбце двумерной матрицы равные элементы
Нужно написать функцию которая определяет есть ли в столбце двумерной матрицы равные элементы и выводит номера этих столбцов

[Ошибка] Максимальный элемент каждой строки двумерной матрицы
Составить программу, которая находит максимальные элементы каждой строки двумерной матрицы A. #include &lt;iostream&gt; #include...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru