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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Одномерные массивы http://www.cyberforum.ru/cpp-beginners/thread225756.html
Нужна помощь: как в одномерном массиве, в котором не задан размер, найти первый и последний элементы??? Например, даны две задачки: 1) Дан массив int arr={4,6,1,2,4,5,9,3}. Вывести на экран сумму...
C++ класс «Строка» (данные-члены класса – строчка, функции-члены класса – операции) Помогите пожалйуста с реализацией программы... Реализовать класс «Строка» (данные-члены класса – строчка (указатель на массив, выделенной памяти на строку), функции-члены класса – операции, которые... http://www.cyberforum.ru/cpp-beginners/thread225723.html
C++ Нелёгкие задания... [S.О.S!]
Полный писец, помогите пожалуйста с заданиями... 1) Задан массив чисел с плавающей запятой F, состоящий из 7 элементов. Вычислить сумму элементов массива и вывести результат. 2) Даны два массива...
Вывести на экран координаты элементов матрицы, которые в своей строке наименьшие C++
Помогите пожалуйста написать программу,которая выводит на экран координаты элементов двумерного массива которые в своей строке наименьшие и одновременно в своем столбце наибольшие.
C++ Не понятные ошибки http://www.cyberforum.ru/cpp-beginners/thread225716.html
Ошибки в след. коде: .cpp(32) : error C2065: S: необъявленный идентификатор .cpp(39) : error C2065: S: необъявленный идентификатор .cpp(41) : error C2046: недопустимый вариант выбора Первый...
C++ Если делать комуто нечего то помогите пожалуйста) Надо написать программу: Ввести строку. Вывести различные слова вместе с количеством их появления в строке. Может ктонибудь с этим делом помочь? А то я несовсем понимаю что надо написать после... подробнее

Показать сообщение отдельно
sandye51
программист С++
685 / 587 / 39
Регистрация: 19.12.2010
Сообщений: 2,016
08.01.2011, 23:43
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
#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.