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

Опредилитель матрицы - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Упражнение http://www.cyberforum.ru/cpp-beginners/thread225765.html
Нужна помощь! Помогите решить упражнение, написав программы на языке С Написать функции для выполнения следующих операций: 1) Копировать строку из одного массива в другой. 2) Добавить символ в...
C++ Определитель матрицы Не могу написать код реккурсивной ф-ии на С для подсчёта опредилителя матрцы nxn, помогите кто чем может: или кодом или алгоритмам зарание благодарю P.S. использовать реккурсию http://www.cyberforum.ru/cpp-beginners/thread225763.html
C++ Одномерные массивы
Нужна помощь: как в одномерном массиве, в котором не задан размер, найти первый и последний элементы??? Например, даны две задачки: 1) Дан массив int arr={4,6,1,2,4,5,9,3}. Вывести на экран сумму...
класс «Строка» (данные-члены класса – строчка, функции-члены класса – операции) C++
Помогите пожалйуста с реализацией программы... Реализовать класс «Строка» (данные-члены класса – строчка (указатель на массив, выделенной памяти на строку), функции-члены класса – операции, которые...
C++ Нелёгкие задания... [S.О.S!] http://www.cyberforum.ru/cpp-beginners/thread225718.html
Полный писец, помогите пожалуйста с заданиями... 1) Задан массив чисел с плавающей запятой F, состоящий из 7 элементов. Вычислить сумму элементов массива и вывести результат. 2) Даны два массива...
C++ Вывести на экран координаты элементов матрицы, которые в своей строке наименьшие Помогите пожалуйста написать программу,которая выводит на экран координаты элементов двумерного массива которые в своей строке наименьшие и одновременно в своем столбце наибольшие. подробнее

Показать сообщение отдельно
sandye51
программист С++
685 / 587 / 39
Регистрация: 19.12.2010
Сообщений: 2,016
15.01.2011, 16:15
xsergx, правда на С++)))
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
76
77
78
79
80
81
82
/*Определитель матрицы*/
 
#include <vector>
#include <algorithm>
#include <fstream>
#include <iterator>
#include <iostream>
#include <conio.h>
 
using namespace std;
 
class nulled : public unary_function<vector<double>, bool>
{
public:
        bool operator() (const vector<double>& Buffer)
        {
                return !(*Buffer.begin());
        }
};
 
class chg : public binary_function<vector<double>, vector<double>, bool>
{
public:
        bool operator()(const vector<double>& Buffer1, const vector<double>& Buffer2)
        {
                return *Buffer1.begin() > *Buffer2.begin();
        }
};
 
class chg2 : public binary_function<vector<double>, vector<double>, bool>
{
public:
        bool operator()(const vector<double>& Buffer1, const vector<double>& Buffer2)
        {
                return *Buffer1.begin() < *Buffer2.begin();
        }
};
 
void out(vector<vector<double> >& Buffer)
{
        cout << endl;
        for (vector<vector<double> >::iterator i = Buffer.begin(), end = Buffer.end(); i != end; ++i, cout << endl)
                copy(i->begin(), i->end(), ostream_iterator<double>(cout, "  "));
}
 
double Determinant(vector<vector<double> >& Buffer)
{
        sort(Buffer.begin(), Buffer.end(), chg2());     
        if (all_of(Buffer.begin(), Buffer.end(), nulled()))
                return 0;
        vector<vector<double> >::iterator fisrt = Buffer.begin();
        if (Buffer.size() == 1)
                return *fisrt->begin();
        for (vector<vector<double> >::iterator i = Buffer.begin() + 1, end = Buffer.end(); i != end; ++i)
        {
                double T = *i->begin() / *fisrt->begin(); 
                transform(fisrt->begin(), fisrt->end(), i->begin(), i->begin(),
                [&T](const double& value1, const double& value2)->double
                {
                        return value2 - value1 * T;
                });
        }
        sort(Buffer.begin() + 1, Buffer.end(), chg());  
        vector<vector<double> > matrix(Buffer.size() - 1);
        for (vector<vector<double> >::iterator i = Buffer.begin() + 1, end = Buffer.end(), Tmp = matrix.begin(); i != end; ++i)
                copy(i->begin() + 1, i->end(), back_inserter(*Tmp++));
        return *fisrt->begin() * Determinant(matrix);
}
 
int main()
{
        fstream file("test.txt");
        size_t n; 
        file >> n;
        vector<vector<double> > matrix(n, vector<double>(n));
        for (vector<vector<double> >::iterator i = matrix.begin(), end = matrix.end(); i != end; ++i)
                for (vector<double>::iterator j = i->begin(), end = i->end(); j != end; ++j)
                        file >> *j;
        cout << "Determinate \n" << static_cast<int>(Determinant(matrix));
        _getch();
        return EXIT_SUCCESS;
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru