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

Если в матрице есть одна строка, сумма элементов которой отрицательна, создать новую матрицу по правилу

05.01.2011, 12:11. Показов 1976. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Люди, кто-нибудь знает как задачку решить? Хотя бы на мысль подтолкните плизззз))

Составить программу, которая получает матрицу А размером m*n. Если в исходной матрице есть, по крайней мере, одна строка, сумма элементов которой отрицательна, то формируется новая матрица из исходной так, что строки в ней расположены в порядке возрастания сумм элементов этих строк.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.01.2011, 12:11
Ответы с готовыми решениями:

Получить новую матрицу, элементы которой есть сумма элементов данной матрицы
4 2 3 4 0 7 5 -2 -4 3 2 8 4 -2 8 3 Получить новую матрицу, элементы которой есть сумма элементов данной матрицы с наименьшим...

Получить новую матрицу, элементы которой есть сумма элементов данной матрицы с наименьшим элементом
Получить новую матрицу, элементы которой есть сумма элементов данной матрицы с наименьшим элементом среди расположенных ниже побочной...

Получить новую матрицу, элементы которой есть сумма элементов данной матрицы с наименьшим элементом среди
4 2 3 4 1 7 5 -2 -4 3 2 8 4 -2 8 3 Получить новую матрицу, элементы которой есть ...

2
 Аватар для Алексaндр
131 / 108 / 12
Регистрация: 04.12.2010
Сообщений: 313
05.01.2011, 12: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
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
#include<conio.h>
#include<iostream>
using namespace std;
 
main()
{
int A[100][100], n, m, i, j, fl=0, s=0, sum[100]={0}, b[100]={0};
cout<<"Enter n and m\n\n";
cin>>n>>m;
for (i=0; i<n; i++) for (j=0; j<m; j++) A[i][j]=rand()%100-50;
cout<<"\n\n A[][] : \n\n";
for (i=0; i<n; i++) 
{
    s=0;
    for (j=0; j<m; j++)
    {
         cout<<A[i][j]<<" ";
         s+=A[i][j];
    }
    b[i]=i;
    if (s<0) fl=1;
    cout<<"\n";
}
for (i=0; i<n; i++)
{
    for (j=0; j<m; j++)
    {
        sum[i]+=A[i][j];
    }
}
if (fl==1)
{
          for (i=0; i<n-1; i++)
          {
              for (j=0; j<m-1; j++)
              {
                  if (sum[j]>sum[j+1])
                  {
                            sum[j]=sum[j]+sum[j+1];
                            sum[j+1]=sum[j]-sum[j+1];
                            sum[j]=sum[j]-sum[j+1];
                            b[j]=b[j]+b[j+1];
                            b[j+1]=b[j]-b[j+1];
                            b[j]=b[j]-b[j+1];
                  }
              }
          }
}
int u;
cout<<"\n A1[][] :\n\n";
for (i=0; i<n; i++)
{
    u=b[i];
    for (j=0; j<m; j++)
    {
        cout<<A[u][j]<<" ";
    }
    cout<<"\n";
}
getch();
}
По-моему, работает... =)
1
 Аватар для igorrr37
2878 / 2025 / 992
Регистрация: 21.12.2010
Сообщений: 3,779
Записей в блоге: 10
05.01.2011, 14:50
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

вот ещё потестируйте
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
#include<iostream>
#include<iomanip>
#include<stdio.h>
#include<map>
#include<algorithm>
using namespace std;
 
int main(){
    int n, m, i, j, sum=0;
    multimap<int, int>sor;
    cout<<"Chislo strok matrici: n=";
    cin>>n;
    cout<<"\nChislo stolbcov matrici: m=";
    cin>>m;
    int **mat=new int *[n];
    for(i=0;i<n;i++)mat[i]=new int[m];
    cout<<"\n\nEnter elements\n\n";
    for(i=0;i<n;i++){
        for(j=0;j<m;j++){
            printf("mat[%d][%d]= ", i, j);
            cin>>mat[i][j];
            sum+=mat[i][j];
        }
        sor.insert(pair<int, int>(sum, i));
        sum=0;
        cout<<endl;
    }
    cout<<"\nSozdana matrica\n\n";
    for(i=0;i<n;i++){
        for(j=0;j<m;j++){
            cout<<setw(4)<<mat[i][j]<<" ";
        }
    cout<<"\n\n";
    }
    multimap<int, int>::iterator it=sor.begin();
    if(it->first>=0)return 0;
    int **mat1=new int *[n];
    for(i=0;i<n;i++)mat1[i]=new int[m];
    for(i=0;i<n;i++){
        copy(mat[it->second], mat[it->second]+m, mat1[i]);
        ++it;
    }
    cout<<"\nAfter sorting\n\n";
    for(i=0;i<n;i++){
        for(j=0;j<m;j++){
            cout<<setw(4)<<mat1[i][j]<<" ";
        }
    cout<<"\n\n";
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.01.2011, 14:50
Помогаю со студенческими работами здесь

В матрице (6,6) заменить в строке все отрицательные элементы на 0, если сумма элементов этой строки отрицательна.
В матрице (6,6) заменить в строке все отрицательные элементы на 0, если сумма элементов этой строки отрицательна. (Примечание: ввод из...

Сформировать из фрагмента матрицы А(na,ma) новую матрицу B(nb,mb), сумма элементов в которой максимальна.
Помогите с задачей на С++, пожалуйста. Сформировать из фрагмента матрицы А(na,ma) новую матрицу B(nb,mb), сумма элементов в которой...

В матрице после каждой строки, сумма элементов которой больше 10, вставить новую строку
В двумерном массиве после каждой строки, сумма элементов которой больше 10, вставить новую строку, каждый элемент которой совпадает с...

Найти в матрице числа строк, сумма элементов у которых отрицательна
Доброго времени суток, начал потихоньку изучать данный язык, и наткнулся на не понимания формулировки задачи. &quot;Составить программу...

Проверить, есть ли в матрице хотя бы одна строка, содержащая положительный элемент, и найти ее номер. Знаки элементов предыдущей строки изменить на пр
Проверить, есть ли в матрице хотя бы одна строка, содержащая положительный элемент, и найти ее номер. Знаки элементов предыдущей строки...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru