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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
LastOne
0 / 0 / 0
Регистрация: 05.04.2010
Сообщений: 7
#1

Квадратная матрица - C++

05.04.2010, 18:12. Просмотров 513. Ответов 6
Метки нет (Все метки)

Ребят, помогите пожалуйста, нужно решить вот такую задачку:
Дана действительная квадратная матрица порядка n. Выяснить, верно ли что наибольшее из значений элементов главной диагонали больше, чем наименьшее из значений элементов побочной диагонали.

Задача вроде бы легкая, но я в совсем не понимаю в программировании
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.04.2010, 18:12     Квадратная матрица
Посмотрите здесь:

C++ Квадратная матрица
Квадратная матрица C++
C++ Квадратная матрица
C++ Квадратная матрица
C++ квадратная матрица
C++ Квадратная матрица
Квадратная матрица C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
yanyk1n
4326 / 1457 / 152
Регистрация: 12.03.2009
Сообщений: 5,310
05.04.2010, 18:32     Квадратная матрица #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>
using namespace std;
void Fill(int ** mas, int N, int M);
void Print(const int * const* mas, int N, int M);
 
int main()
{
    int N, M;
    cout << "Введите размерность матрицы A(N,N) -> ";
    cin >> N;
    int ** a = new int * [N];
    for (int i = 0 ; i < N ; i++) a[i] = new int [N];
    Fill(a, N, N);
    cout << "Исходная матрица" << endl;
    Print(a, N, N);
    int max1 = a[0][0];
    int min2 = a[0][N-1];   
    for (int i = 0 ; i < N; i++)
    {
        if (a[i][i] > max1) max1 = a[i][i];
        if (a[i][N-i-1] < min2) min2 = a[i][N-i-1];
    }
    if (max1 > min2)
    {
        cout << "Верно" << endl;
    } else cout << "Неверно" << endl;
    for (int i = 0 ; i < N ; i++) delete [] a[i];
    delete [] a;
    return 0;
}
 
void Fill(int ** mas, int N, int M)
{   
    for (int i = 0 ; i < N ; i++)
    {
        for (int j = 0 ; j < M ; j++)
        {
            cout << "A[" << i << "," << j << "] -> ";
            cin >> mas[i][j];
        }
    }   
}
LastOne
0 / 0 / 0
Регистрация: 05.04.2010
Сообщений: 7
05.04.2010, 18:52  [ТС]     Квадратная матрица #3
а можно с комментариями? просто это еще и защищать придется...(
UKOL
112 / 64 / 7
Регистрация: 17.11.2009
Сообщений: 258
05.04.2010, 21:24     Квадратная матрица #4
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 <time.h>
 
int main()
{       
        setlocale(LC_ALL, "Russian");//инициализация русского языка
        srand(time(NULL));//генерация случайных чисел по времени
        const int N=5;//размер матрицы
        int matrix[N][N]={0};//инициализация массива NxN и обнуление всех элементов
        //заполнение матрицы случайными числами
        for(int i=0;i<N;i++)
                for(int j=0;j<N;j++)
                        matrix[i][j]=rand()%10;//числа от 0 до 9
 
        //выводим на экран матирцу
        for(int i=0;i<N;i++)
        {
                for(int j=0;j<N;j++)
                {
                        std::cout << matrix[i][j] << " ";
                }
                std::cout << std::endl;
        }
        
        
        //поиск минимальных чисел в главной диагонали
        //определяем минимум, как элемент матрицы 0,0
        int maxGlav=matrix[0][0];
        for(int i=1,j=1;((i<N)&&(j<N));i++,j++)
                if(maxGlav<matrix[i][j])
                        maxGlav=matrix[i][j];
 
        //определяем минимальный элемент побочной диагонали
        //определяем минимум, как элемент матрицы 0,N-1
        int minPoboch=matrix[0][N-1];
        for(int i=0,j=N-1;((i<N)&&(j<N));i++,j--)
                if(minPoboch>matrix[i][j])
                        minPoboch=matrix[i][j];
 
        std::cout << "Максимальный элемент главной диагонали: " << maxGlav << std::endl;
        std::cout << "Минимальный элемент побочной диагонали: " << minPoboch << std::endl;
        
        //сравнение максимально с минимальным
        if(maxGlav>minPoboch)
            std::cout << "Верно!" << std::endl;
        else 
            std::cout << "Не верно!" << std::endl;
        return 0;
}
LastOne
0 / 0 / 0
Регистрация: 05.04.2010
Сообщений: 7
05.04.2010, 22:13  [ТС]     Квадратная матрица #5
спасибо, тут уже более понятно
Цитата Сообщение от UKOL Посмотреть сообщение
C++
1
2
3
#include <iostream>
#include <iomanip>
#include <time.h>
а эти команды а что отвечают? мы такого не проходили..
UKOL
112 / 64 / 7
Регистрация: 17.11.2009
Сообщений: 258
05.04.2010, 22:41     Квадратная матрица #6
<iomanip> убери тут не нужен

а первая и третья директива это ввод, вывод и инициализация времени в программе соответственно.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.04.2010, 22:53     Квадратная матрица
Еще ссылки по теме:

квадратная матрица C++
C++ Квадратная матрица
C++ Квадратная матрица
Квадратная матрица C++
Квадратная матрица C++

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

Или воспользуйтесь поиском по форуму:
LastOne
0 / 0 / 0
Регистрация: 05.04.2010
Сообщений: 7
05.04.2010, 22:53  [ТС]     Квадратная матрица #7
спасибо, теперь более-менее понятно
Yandex
Объявления
05.04.2010, 22:53     Квадратная матрица
Ответ Создать тему
Опции темы

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