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

динамические массивы.матрицы

24.12.2011, 14:08. Показов 1985. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
пожалуйста,помогите решить задачу на языке Си((

Дана матрица размера M  N. Продублировать 2 раза столбец матрицы, содержащий ее минимальный элемент.

очень нужно!!!заранее спасибо)))
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.12.2011, 14:08
Ответы с готовыми решениями:

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

Поменять местами указанные столбцы заданной матрицы (динамические массивы)
ДИНАМИЧЕСКИЕ МАССИВЫ. Поменять местами столбцы матрицы с номерами i и j.

Выполнить циклический сдвиг элементов квадратной матрицы, используя локальные и динамические массивы
Осуществить циклический сдвиг элементов квадратной матрицы размерность M x N вправо на k элементов таким образом: элементы первой строки...

9
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,245
24.12.2011, 14:40
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
// создаем динамическую матрицу
int **mass=new int*[m];
for(int i=0;i<m;i++)
    *mass[i]=new int[n];
// ищем минимальный элемент 
int imin=mass[0][0];int i0=0,j0=0;
for(int i=0;i<m;i++)
     for(int j=0;j<m;j++)
           if(mass[i][j]<imin)
           {
                  imin=mass[i][j];
                  i0=i;j0=j;
           }
// а теперь надо решить, что значит продублировать.
// пусть это значит стереть два следующих и вместо них записать столбец с минимумом
for(int i=0;i<m;i++)
    for(int j=j0+1;j<j0+3;j++)
               m[i][j]=m[i][j0];
// выводим результат
for(int i=0;i<m;i++)
{
     for(int j=0;j<m;j++)
            cout<<m[i][j]<<"  ";
     cout<<endl;
}
// удаляем динамическую матрицу
for(int i=0;i<m;i++)
     delete[] mass[i];
delete[] mass;
0
0 / 0 / 0
Регистрация: 24.12.2011
Сообщений: 5
24.12.2011, 14:54  [ТС]
спасибо!но продублировать это значит после столбца с минимумом вставить такой же,тоесть перезаписать в матрицу размерностью на один столбец больше!
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,245
24.12.2011, 15:05
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
// создаем динамическую матрицу c n+2 столбцами
int **mass=new int*[m];
for(int i=0;i<m;i++)
    *mass[i]=new int[n+2];
// Заполяем m на n элементов
for(int i=0;i<m;i++)
     for(int j=0;j<n;j++)
         mass[i][j]=rand();
// ищем минимальный элемент 
int imin=mass[0][0];int i0=0,j0=0;
for(int i=0;i<m;i++)
     for(int j=0;j<n;j++)
           if(mass[i][j]<imin)
           {
                  imin=mass[i][j];
                  i0=i;j0=j;
           }
// а теперь надо решить, что значит продублировать.
// пусть это значит вставить следом два новых а остальные сдвинуть
for(int i=0;i<m;i++)
    for(int j=n-1;j>j0;j--)
               m[i][j+2]=m[i][j];
for(int i=0;i<m;i++)
    for(int j=j0+1;j<j0+3;j++)
               m[i][j]=m[i][j0];
// выводим результат
for(int i=0;i<m;i++)
{
     for(int j=0;j<n+2;j++)
            cout<<m[i][j]<<"  ";
     cout<<endl;
}
// удаляем динамическую матрицу
for(int i=0;i<m;i++)
     delete[] mass[i];
delete[] mass;
0
0 / 0 / 0
Регистрация: 24.12.2011
Сообщений: 5
24.12.2011, 15:28  [ТС]
спасибо,но не работает(
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,245
24.12.2011, 15:53
Цитата Сообщение от Анастасия2908 Посмотреть сообщение
спасибо,но не работает(
конкретизируйте, что не работает.

Добавлено через 5 минут
вот работающий код
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
#include <iostream>
using namespace std;
int main()
{
    int m=4,n=4;
int **mass=new int*[m];
for(int i=0;i<m;i++)
    mass[i]=new int[n];
// ищем минимальный элемент 
int imin=mass[0][0];int i0=0,j0=0;
for(int i=0;i<m;i++)
     for(int j=0;j<m;j++)
           if(mass[i][j]<imin)
           {
                  imin=mass[i][j];
                  i0=i;j0=j;
           }
// а теперь надо решить, что значит продублировать.
// пусть это значит стереть два следующих и вместо них записать столбец с минимумом
for(int i=0;i<m;i++)
    for(int j=j0+1;j<j0+3;j++)
               mass[i][j]=mass[i][j0];
// выводим результат
for(int i=0;i<m;i++)
{
     for(int j=0;j<m;j++)
            cout<<mass[i][j]<<"  ";
     cout<<endl;
}
// удаляем динамическую матрицу
for(int i=0;i<m;i++)
     delete[] mass[i];
delete[] mass;
  return 0;
}
0
0 / 0 / 0
Регистрация: 24.12.2011
Сообщений: 5
24.12.2011, 15:53  [ТС]
не работает часть с удалением,сдвигом..
ввод матрицы я осуществляю неким другим способом,и минимум я тоже нашла,а вот продублировать..((
и кстати,вы походу всё же не правильно меня поняли,продублировать-вставить следом за столбцом ОДИН такой же столбец
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,245
24.12.2011, 15:55
for(int j=j0+1;j<j0+3;j++)
mass[i][j]=mass[i][j0];
j принимает значения j0+1,j0+2 - значит 2 столбца
0
0 / 0 / 0
Регистрация: 24.12.2011
Сообщений: 5
24.12.2011, 15:57  [ТС]
вобщем спасибо за усилия,буду пытаться решить сама
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,245
24.12.2011, 20:01
Цитата Сообщение от Анастасия2908 Посмотреть сообщение
пожалуйста,помогите решить задачу на языке Си((

Дана матрица размера M  N. Продублировать 2 раза столбец матрицы, содержащий ее минимальный элемент.

очень нужно!!!заранее спасибо)))
В задании написано 2 раза.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.12.2011, 20:01
Помогаю со студенческими работами здесь

Динамические массивы. Найти наибольшие элементы каждой строки матрицы Х и записать их в массив Y
Найти наибольшие элементы каждой строки матрицы Х и записать их в массив Y. Размер Марицы вводить с клавиатуры, а элементы разместить в...

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

Динамические массивы и функции. Динамические массивы.
Дана матрица 6х8 целого типа. Создать одномерный массив, содержащий элементы матрицы, кратные числу, введенному с клавиатуры.

Указатели и массивы. Индексация с помощью указателей. Передача массивов в функции. Динамические массивы (обработка матриц)
Для каждого элемента , bij, i= 1,...,n , j=1,...,n определяется свой многоугольник местонахождением соответствующего элемента aij (см....

Структуры, массивы, указатели, динамические массивы структур
Помогите с решением задачи (прикрепляю условие). Заранее спасибо.


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru