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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 17, средняя оценка - 4.59
maxez
1 / 1 / 0
Регистрация: 28.11.2011
Сообщений: 32
06.09.2012, 10:52     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #1
Дана вещественная прямоугольная матрица. Найти сумму элементов в строках с отрицательным элементом на главной диагонали. Если сумма больше 0, то элементы последней строки возвести в квадрат.

Помогите пожалуйста.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.09.2012, 10:52     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали
Посмотрите здесь:

C++ Найти сумму элементов матрицы, которые размещены в строках с отрицательным элементом на главной диагонали
Для заданной матрицы A(N, N) найти сумму элементов, расположенных в строках с отрицательным элементом на главной диагонали C++
Дана действительная квадратная матрица порядка 8. В строках с отрицательным элементом на главной диагонали найти сумму всех элементов C++
C++ В строках матрицы с отрицательным элементом на главной диагонали найти наибольший из всех элементов (найти ошибку в коде)
C++ В строках матрицы с отрицательным элементом на главной диагонали найти суму всех элементов и максимальный элемент
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
David Sylva
 Аватар для David Sylva
1281 / 943 / 51
Регистрация: 17.05.2012
Сообщений: 2,686
06.09.2012, 11:18     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #2
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
#include <iostream>
#include <iomanip>
#include <ctime> 
#include <cstdlib> 
using namespace std; 
 
int main() 
{   
    setlocale(0, "rus");
    srand((unsigned) time(0));
    const int size = 5; 
    int matrix[size][size]; 
    unsigned int i, j;  
    int summa = 0;
 
    for ( i = 0; i < size; i++) 
        for ( j = 0; j < size; j++) 
        { 
            matrix[i][j] = rand() % 201 - 100; 
            if( j % (size + 1) == 0) 
                cout << endl; 
            cout << setw(3) << matrix[i][j];
        }  
        cout << endl; 
 
        for ( i = 0; i < size; i++)  
        {
            for ( j = 0; j < size; j++)  
            {
                if(matrix[i][i] < 0) 
                  summa += matrix[i][j];  
            }  
            if(matrix[i][i] < 0) 
            {
            cout << "Сумма строки " << i << " равна " << summa << endl;  
            if(summa > 0) 
                cout << "Квадрат последнего элемента равен " << matrix[i][size-1] * matrix[i][size-1] << endl;
            
        } 
        summa = 0;
        }
}
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
06.09.2012, 11:40     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #3
автору поста выше низачот. совсем низачот

тыщу лет не писал на плюсах.
вроде вот по условию:
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
#include <iostream>
#include <cstdlib>
 
int main() {
    int N;
    std::cout << "Enter number of rows: ";
    std::cin  >> N;
    int M;
    std::cout << "Enter number of columns: ";
    std::cin  >> M;
    
    // fill matrix
    float **matrix = new flaot* [N];
    for ( int i = 0; i < N; i ++ ) {
        matrix[i] = new float [M];
        for ( int j = 0; j <  M; j ++ ) {
            matrix[i][j] = (std::rand()%10 - std::rand()%10) / std::rand()%5;
        }
    }
    
    // print matrix
    for ( int i = 0; i < N; i ++ ) {
        for ( int j = 0; j < M; j ++ ) {
            std::cout << matrix[i][j] << "\t";
        }
        std::cout << std::endl;
    }
    
    // cheack and adding
    int total = 0;
    for ( int i = 0; i < N; i ++ ) {
        if ( matrix[i][i] < 0 ) {
            for ( int j = 0; j < M; j ++ )
                total += matrix[i][j]; 
        }
    }
    // multiply
    if ( total > 0 ) {
        for ( int j = 0; j < M; j ++ )
        {
            matrix [N-1][j] *= matrix[N-1][j];
        }
    }
    
    // print matrix
    for ( int i = 0; i < N; i ++ ) {
        for ( int j = 0; j < M; j ++ ) {
            std::cout << matrix[i][j] << "\t";
        }
        std::cout << std::endl;
    }
        std::cout << "\nTotal = " << total;
    
    return 0;
}
David Sylva
 Аватар для David Sylva
1281 / 943 / 51
Регистрация: 17.05.2012
Сообщений: 2,686
06.09.2012, 11:50     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #4
Ты вообще co6ak свой код компилировал? Сначала исправь свои ошибки, а потом выставляй оценки другим
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
06.09.2012, 12:04     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #5
у меня и компилятора то нет. но ТЗ не выполнено
дай линк на компиль онлайн какой-нить.

Добавлено через 2 минуты
ой. две опечатки. прям гора ошибок ))

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
#include <iostream>
#include <cstdlib>
 
int main() {
    int N;
    std::cout << "Enter number of rows: ";
    std::cin  >> N;
    int M;
    std::cout << "Enter number of columns: ";
    std::cin  >> M;
    
    // fill matrix
    float **matrix = new float* [N];
    for ( int i = 0; i < N; i ++ ) {
        matrix[i] = new float [M];
        for ( int j = 0; j <  M; j ++ ) {
            matrix[i][j] = (std::rand()%10 - std::rand()%10) / std::rand()%5;
        }
    }
    
    // print matrix
    for ( int i = 0; i < N; i ++ ) {
        for ( int j = 0; j < M; j ++ ) {
            std::cout << matrix[i][j] << "\t";
        }
        std::cout << std::endl;
    }
    
    // cheack and adding
    float total = 0;
    for ( int i = 0; i < N; i ++ ) {
        if ( matrix[i][i] < 0 ) {
            for ( int j = 0; j < M; j ++ )
                total += matrix[i][j]; 
        }
    }
    // multiply
    if ( total > 0 ) {
        for ( int j = 0; j < M; j ++ )
        {
            matrix [N-1][j] *= matrix[N-1][j];
        }
    }
    
    // print matrix
    for ( int i = 0; i < N; i ++ ) {
        for ( int j = 0; j < M; j ++ ) {
            std::cout << matrix[i][j] << "\t";
        }
        std::cout << std::endl;
    }
        std::cout << "\nTotal = " << total;
    
    return 0;
}
David Sylva
 Аватар для David Sylva
1281 / 943 / 51
Регистрация: 17.05.2012
Сообщений: 2,686
06.09.2012, 12:06     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #6
Объясни суть претензий к моему коду, я восприимчив к критике.
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
06.09.2012, 12:10     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #7
Найти сумму элементов в строках с отрицательным элементом на главной диагонали. Если сумма больше 0, то элементы последней строки возвести в квадрат
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
for ( i = 0; i < size; i++)  
        {
            for ( j = 0; j < size; j++)  
            {
                if(matrix[i][i] < 0) 
                  summa += matrix[i][j];  
            }  
            if(matrix[i][i] < 0) 
            {
            cout << "Сумма строки " << i << " равна " << summa << endl;  
            if(summa > 0) 
                cout << "Квадрат последнего элемента равен " << matrix[i][size-1] * matrix[i][size-1] << endl;
            
        } 
        summa = 0;
        }
вот это ад. первый цикл по J можно было сделать вложенным, что б не проверять его 300 раз. зачем проверять matrix[i][i] кол-во раз, равное i * j ? )
глянь у меня вложенный цикл после проверки только запускается. и в тз нет "сумму в каждой строке" и "квадрата последнего элемента строки с отрицательной суммой"
David Sylva
 Аватар для David Sylva
1281 / 943 / 51
Регистрация: 17.05.2012
Сообщений: 2,686
06.09.2012, 12:14     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #8
Согласен.
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
06.09.2012, 12:23     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #9
не ошибается только тот - кто ни чего не делает )
maxez
1 / 1 / 0
Регистрация: 28.11.2011
Сообщений: 32
23.10.2012, 07:54  [ТС]     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #10
Дана вещественная прямоугольная матрица. Найти сумму элементов в строках с отрицательным элементом на главной диагонали. Если сумма больше 0, то элементы последней строки возвести в квадрат.

Желательно использовать только библиотеки <iostream.h> и <iomanip.h>


Помогите пожалуйста.
Lana_levchuk
5 / 5 / 0
Регистрация: 21.10.2012
Сообщений: 26
23.10.2012, 10:42     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #11
Такой вариант, если не требуется вводить элементы с клавиатуры. Размер и наполнение на ваше усмотрение.
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
// 
#include "stdafx.h"
#include <iostream>
#include <conio.h>
using namespace std;
const int N1=4;
const int N2=4;
 
 
int main()
{ 
    setlocale (LC_ALL,"Russian");
    float summ;
    double massive [N1][N2]=
    {
        {4,0,0,0},
        {0,-2,0,0},
        {0,0,1,0},
        {0,15,0,-10}
    };
    summ=0;
    for (int i=0;i<N1;i++)
        for (int j=0;j<N2;j++)
            {
            if ((i==j)&&(massive[i][j]<0))
                {   
                    for (int k=0;k<N2;k++)
                    summ=summ+massive[i][k];
                }
            }
        cout<<"Сумма элементов равна: "<<summ<<endl;
 
        if (summ>0) 
            {
                cout<<"Квадрат элементов последней строки соответственно равен:"<<endl;
                for (int i=0;i<N1;i++)
                for (int j=0;j<N2;j++)
                    if (i==(N1-1))
                        cout<<massive [i][j]*massive [i][j]<<"  ";  
            }
        if (summ==0)
            cout<<"Отрицательные элементы на главной диагонали отсутствуют! "<<endl;
        if (summ<0) cout<<"Сумма меньше 0! "<<endl;
        ;
    _getch ();      
    return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.10.2012, 12:38     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали
Еще ссылки по теме:

Найти минимальный из элементов ниже главной и выше побочной диагонали и поменять его местами с первым элементом матрицы C++
В строках матрицы с отрицательным элементом на главной диагонали найти наибольший из всех элементов C++
C++ В столбцах с отрицательным элементом на главной диагонали найти сумму всех элементов

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

Или воспользуйтесь поиском по форуму:
maxez
1 / 1 / 0
Регистрация: 28.11.2011
Сообщений: 32
23.10.2012, 12:38  [ТС]     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали #12
Цитата Сообщение от Lana_levchuk Посмотреть сообщение
Такой вариант, если не требуется вводить элементы с клавиатуры. Размер и наполнение на ваше усмотрение.
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
// 
#include "stdafx.h"
#include <iostream>
#include <conio.h>
using namespace std;
const int N1=4;
const int N2=4;
 
 
int main()
{ 
    setlocale (LC_ALL,"Russian");
    float summ;
    double massive [N1][N2]=
    {
        {4,0,0,0},
        {0,-2,0,0},
        {0,0,1,0},
        {0,15,0,-10}
    };
    summ=0;
    for (int i=0;i<N1;i++)
        for (int j=0;j<N2;j++)
            {
            if ((i==j)&&(massive[i][j]<0))
                {   
                    for (int k=0;k<N2;k++)
                    summ=summ+massive[i][k];
                }
            }
        cout<<"Сумма элементов равна: "<<summ<<endl;
 
        if (summ>0) 
            {
                cout<<"Квадрат элементов последней строки соответственно равен:"<<endl;
                for (int i=0;i<N1;i++)
                for (int j=0;j<N2;j++)
                    if (i==(N1-1))
                        cout<<massive [i][j]*massive [i][j]<<"  ";  
            }
        if (summ==0)
            cout<<"Отрицательные элементы на главной диагонали отсутствуют! "<<endl;
        if (summ<0) cout<<"Сумма меньше 0! "<<endl;
        ;
    _getch ();      
    return 0;
}
А я уже сам справился.

C++ (Qt)
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
#include <iostream.h>
#include <iomanip.h>
 
vvod(int *A,int n);
raschet(int *A,int n);
vivod(int *A,int n);
 
vvod(int *A,int n)
 {
int i,j;
cout<<"Vvedite pryamougolnuy matricu."<<endl;
for(i=0;i<n;i++)
   for(j=0;j<n;j++)
      cin>>*(A+i*n+j);
cout<<endl;
return 0;
  }
 
 
  raschet(int *A,int n)
{
int i,j,s,x;
s=0;
for(i=0;i<n;i++)
   if(*(A+i*n+i)<0)
    {
           for(j=0;j<n;j++)
            s=s+*(A+i*n+j);
      }
    if(s>0)
    {
    i=n-1;
    for(j=0;j<n;j++)
    *(A+i*n+j)=*(A+i*n+j)**(A+i*n+j);
    }
}
vivod(int *A,int n)
{
int i,j,s,x;
cout<<"Poluchennaya matrica."<<endl;
for(i=0;i<n;i++)
{
  for(j=0;j<n;j++)
     cout<< setw(5)<<*(A+i*n+j);
  cout<<endl;
}
}
 
void main()
{
int *A,n,i,j;
cout<<"Vvedite razmernost."<<endl;
cin>>n;
A=new int[n*n];
vvod(A,n);
raschet(A,n);
vivod(A,n);
cin>>n;
}
Yandex
Объявления
23.10.2012, 12:38     Найти сумму элементов матрицы в строках с отрицательным элементом на главной диагонали
Ответ Создать тему
Опции темы

Текущее время: 09:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru