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

Использование функций шаблонов (выяснить, является ли матрица симметричной относительно главной диагонали) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти строку матрицы с максимальной суммой элементов http://www.cyberforum.ru/cpp-beginners/thread836007.html
Дано двумерный массив целых чисел, найти строку с максимальной суммой элементов. Помогите сделать, или хотя бы напишите часть как найти строку с максимальной суммой элементов...
C++ Решение уравнений - последовательность действий Дано 3 числа. Между ними можно ставить знаки математических операций: сложение, вычитание, умножение, деление. Сколько различных значений может образоваться в результате вычисления полученных таким... http://www.cyberforum.ru/cpp-beginners/thread835997.html
C++ Разработать рекурсивную функцию, возвращающую значение
Разработать рекурсивную функцию, возвращающую значение: для вычисления значения функции:
C++ C++ подключение с MySQL
Мне нужно подключиться к MySQL. Я видел примеры подключения, где используются какие-то дравера ODBC... Объясните мне пожалуйста, обязательно ли нужны эти драйвера? Я люблю писать без лишних вещей и...
C++ Разработать рекурсивную функций, возвращающую значение для нахождения НОД методом Евклида http://www.cyberforum.ru/cpp-beginners/thread835939.html
разработать рекурсивную функций,возвращающую значение для нахождения НОД методом Евклида НОД(a,b)=а,если a=b НОД(a-b,b),если a>b НОД(a,b-a),если b>a помогите...
C++ Вывести повторяющиеся элементы Задан целочисленный массив Х из 20 элементов, среди которых есть повторяющиеся. Записать в массив Y по одному элементу из каждой группы одинаковых значений исходного массива. подробнее

Показать сообщение отдельно
xtorne21st
интересующийся
304 / 275 / 19
Регистрация: 25.09.2010
Сообщений: 1,056
12.04.2013, 21:02
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#include <iostream>
 
// Шаблонная функция isinorder(), которая принимает указатель на указатель
// на тип T, а также переменную y и x типа size_t и возвращает тип bool.
template <typename T>
bool isinorder(T** base, size_t y, size_t x)
{
    if (y != x) // Если матрица не квадратная, то дальше проверять смысла нет.
    {
        return false;
    }
 
    for (size_t i = 1; i <= y/2 ;++i)
    {
        // проверям являетя ли она симметричной.
        if (base[i-1][x-i] != base[y-i][i-1])
        {
            return false;
        }
    }
    return true;
}
 
// Функция просто отображает содержимое матирицы.
template <typename T>
void showArr(T** base, size_t y, size_t x)
{
    for (size_t i = 0; i < y; ++i)
    {
        for (size_t j = 0; j < x; ++j)
        {
            std::cout.width(3); // растояние между значениями равно 3 символа.
            std::cout << base[i][j] << ' ';
        }
        std::cout << '\n';
    }
}
 
int main()
{
    const int size = 3; // размер матрицы.
 
    // Создание матрицы типа int.
    int** arr = new int*[size];
    for (int i = 0; i < size; ++i)
    {
        arr[i] = new int[size];
    }
 
    // Заполняем её вручную с консоли.
    for (int i = 0; i < size; ++i)
    {
        for (int j = 0; j < size; ++j)
        {
            std::cin >> arr[i][j];
        }
    }
 
    // Отображаем матрицу.
    showArr<int>(arr, size, size);
 
    // Отображем результат проверки.
    // std::boolalpha просто выводит значени "true" если значение в cout
    // отлично от нуля и "false" елси равно нулю.
    std::cout << std::boolalpha << isinorder<int>(arr, size, size) << '\n';
 
    // Освобождаем память выделеную пoд матрицу.
    for (int i = 0; i < size; ++i)
    {
        delete [] arr[i];
    }
    delete [] arr;
 
    return 0;
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru