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

В матрице определить сумму элементов, находящихся на главной диагонали - C++

Восстановить пароль Регистрация
 
piOMEN
0 / 0 / 0
Регистрация: 12.04.2010
Сообщений: 20
07.05.2010, 17:35     В матрице определить сумму элементов, находящихся на главной диагонали #1
1. В матрице размерами N*N (N не больше 10) определить сумму элементов, находящихся на главной диагонали. Матрицу сформировать из случайных двузначных чисел.
2. Выяснить, есть ли в заданной матрице одинаковые элементы. Матрица содержит n строк и m столбцов и сформирована из случайных чисел в диапазоне от -10 до 10. Программа должна вывести «да» или «нет».

Помогите пожалуйста!
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.05.2010, 17:35     В матрице определить сумму элементов, находящихся на главной диагонали
Посмотрите здесь:

C++ В матрице размерами N*N (N =<10) определить сумму элементов, находящихся на главной диагонали
Найти сумму модулей элементов матрицы, находящихся выше главной диагонали C++
Найти сумму элементов матрицы, находящихся на диагонали, «ортогональной » главной C++
C++ Найти сумму элементов квадратной матрицы порядка N, находящихся ниже главной диагонали
C++ Найти сумму элементов квадратной матрицы порядка N, находящихся ниже главной диагонали
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,689
07.05.2010, 17:57     В матрице определить сумму элементов, находящихся на главной диагонали #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от piOMEN Посмотреть сообщение
1. В матрице размерами N*N (N не больше 10) определить сумму элементов, находящихся на главной диагонали. Матрицу сформировать из случайных двузначных чисел.
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
#include <iostream>
#include <ctime>
#include <iomanip>
 
int main ()
{
 
std::cout << "Input size of matrix: ";
int N; std::cin >> N;
int **MAS = new int *[N];
for (int i = 0; i < N; i++)
MAS[i] = new int [N];
 
int sum=0; // тут будет хранится сумма.
srand(time(NULL));
std::cout << "Start matrix:\n";
for (int i=0; i<N; i++)
{
    for (int j=0; j<N; j++)
    {
        MAS[i][j]=rand()%89+10; // заполняем матрицу случайными числами,
        std::cout << std::setw(3) << MAS[i][j]; // выводим на экран,
        if (i==j) sum+=MAS[i][j]; // и считаем сумму.
    }
std::cout << std::endl;
}
 
    std::cout << "Summa: " << sum << std::endl;
    for (int i = 0; i < N; i++)
    delete []MAS[i];
    delete []MAS;
    return 0;
}
Добавлено через 13 минут
Цитата Сообщение от piOMEN Посмотреть сообщение
2. Выяснить, есть ли в заданной матрице одинаковые элементы. Матрица содержит n строк и m столбцов и сформирована из случайных чисел в диапазоне от -10 до 10. Программа должна вывести «да» или «нет».
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
#include <iostream>
#include <ctime>
#include <iomanip>
bool search (int **, int, int, int, int); //матрица, ее размеры, индексы элемента.
 
int main ()
{
    int row,column;
    std::cout << "Input number row of matrix: ";
    std::cin >> row;
    std::cout << "Input number column of matrix: ";
    std::cin >> column;
    int **MAS = new int *[row];
    for (int i = 0; i < row; i++)
    MAS[i] = new int [column];
 
    srand(time(NULL));
    std::cout << "Start matrix:\n";
    for (int i=0; i<row; i++)
    {
        for (int j=0; j<column; j++)
        {
            MAS[i][j]=rand()%21-10; // заполняем случайными числами,
            std::cout << std::setw(3) << MAS[i][j]; // выводим на экран.
        }
    std::cout << std::endl;
    }
 
    for (int i=0; i<row; i++)
    for (int j=0; j<column; j++)
        if (search(MAS, row, column, i, j))
        {
            std::cout << "True.\n";
            return 0;
        }
 
    std::cout << "False.\n";
    for (int i = 0; i < row; i++)
    delete []MAS[i];
    delete []MAS;
    return 0;
}
 
bool search (int **MAS, int row, int column, int indexRow, int indexColumn)
{
    for (int i=0; i<row; i++)
    for (int j=0; j<column; j++)
    if ((MAS[i][j]==MAS[indexRow][indexColumn]) && (i!=indexRow) && (j!=indexColumn))
                                return true;
 
    return false;
}
KennyMccormick
0 / 0 / 0
Регистрация: 07.05.2010
Сообщений: 50
07.05.2010, 22:52     В матрице определить сумму элементов, находящихся на главной диагонали #3
system("pause"); перед ретерном в пеhвой задаче еще можно приписать)
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,689
07.05.2010, 22:53     В матрице определить сумму элементов, находящихся на главной диагонали #4
Можно, но в компиляторе в котором я работаю, это не нужно
piOMEN
0 / 0 / 0
Регистрация: 12.04.2010
Сообщений: 20
07.05.2010, 23:27  [ТС]     В матрице определить сумму элементов, находящихся на главной диагонали #5
спасибо товарищ)))
Yandex
Объявления
07.05.2010, 23:27     В матрице определить сумму элементов, находящихся на главной диагонали
Ответ Создать тему
Опции темы

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