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

Определить количество отрицательных в строках, содержащих нули и номера сток и столбцов седловых точек матрицы - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Сравнение строк в структуре http://www.cyberforum.ru/cpp-beginners/thread1111111.html
смысл таков- я ввожу строку char nomerP, и эта строка должна сравниться с char NO и вернуть мне 0 или отличное от 0 значение. Вот вызов функции сравнения if (proverka1(marshryt.NO,nomerP)) { prov=true; вот сама недоделанная функция int proverka1 (char NO,char nomerP) { strcmp(NO, );
C++ Не работает Code::Blocks 13.12 :( На какую IDE можно безболезнено перейти? Последняя версия кодблокс 13.12 вышла на редкость глючной и стала долго запускаться по сравнению с предыдущими версиями. А сейчас нужно было создать новый проект, а он не создается, меню выбора темплейтов не работает, хотя раньше работала. Переустановила кодблокс, но проблема не исчезла. Вобщем достала она меня, на какую IDE можно безболезнено перейти после кодблокс? http://www.cyberforum.ru/cpp-beginners/thread1111105.html
C++ Не работает алгоритм Форда-Фалкерсона
Добрый день уважаемые форумчане! У меня проблема. Реализовал алгоритм Форда-Фалкерсона. Программа компилируется, но правильного результата не выдает. Переделывал ее уже два раза, но все тщетно, поэтому вы - моя последняя надежда. Суть: На вход дан взвешенный ориентированный граф. Нужно найти величину max потока. Начинаем программу, считывая файл data.txt: 5 0 5 4 4 0 -5 0 -1 0 2 -4 1...
чтение формата *.xls C++
Требуется обработать документ формата *.xls (где присутствует объединение итп), провести кое-какие вычисления и вывести результат. Предполагается, что в системе не установлен ни Microsoft Office, ни Open Ofiice (т.е. технология обработки не должна основываться на OLE или COM). Также, приложение должно быть кроссплатформенное (Win & Linux). Я поискал/почитал, нашел несколько специализированных...
C++ Ошибка в создание класса http://www.cyberforum.ru/cpp-beginners/thread1111033.html
Подскажите что не так #include "stdafx.h" #include <stdlib.h> #include <conio.h> #include <string.h> #include <stdio.h> #include <iostream> using namespace std; class students
C++ Ошибка с библиотекой fltk (Ссылка на неразрешенный внешний символ) Изучаю программирование с графикой. У меня проблема выдает следующее сообщения ошибок компиляции 1>main.obj : error LNK2019: ссылка на неразрешенный внешний символ "public: static int __cdecl Fl::run(void)" (?run@Fl@@SAHXZ) в функции _main 1>main.obj : error LNK2019: ссылка на неразрешенный внешний символ "public: void __thiscall Fl_Window::show(int,char * *)" (?show@Fl_Window@@QAEXHPAPAD@Z)... подробнее

Показать сообщение отдельно
Ded_Vasilij
 Аватар для Ded_Vasilij
229 / 211 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
04.03.2014, 18:54     Определить количество отрицательных в строках, содержащих нули и номера сток и столбцов седловых точек матрицы
Файл matrix.h
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
#ifndef MATRIX_H
#define MATRIX_H
 
#include <iostream>
 
class Matrix
{
public:
    Matrix(int size);
    Matrix(const Matrix&);
    ~Matrix();
 
    Matrix& operator= (const Matrix&);
 
    // без проверки индексов
    double operator() (int i, int j) const;
    double& operator() (int i, int j);
 
    // размер матрицы
    int size() const {
        return _size;
    }
 
protected:
    double**    _M;
    int         _size;
 
private:
    void copy(const Matrix&);
    void destroy();
};
 
std::ostream& operator<< (std::ostream&, const Matrix&);
 
// равномерно-распределённая на [0, 1] величина
double drand();
// возвращает случайную симметричную положительно-определённую матрицу A, -M <= A[i][j] <= M
Matrix randomMatrix(int size, double M = 1.0);
 
#endif
Файл matrix.cpp
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#include <cstdlib>
#include <iomanip>
#include "matrix.h"
#include <Windows.h>
Matrix::Matrix(int size): _M(0), _size(size)
{
    _M = new double* [_size];
    for (int i = 0; i < _size; ++i) {
        _M[i] = new double [_size];
        for (int j = 0; j < _size; ++j) {
            _M[i][j] = 0;
        }
    }
}
 
Matrix::Matrix(const Matrix& m)
{
    copy(m);
}
 
Matrix::~Matrix()
{
    destroy();
}
 
Matrix& Matrix::operator= (const Matrix& m)
{
    if (this != &m) {
        destroy();
        copy(m);
    }
    return *this;
}
 
double Matrix::operator() (int i, int j) const
{
    return _M[i][j];
}
 
double& Matrix::operator() (int i, int j)
{
    return _M[i][j];
}
 
void Matrix::copy(const Matrix& m)
{
    _size = m._size;
    _M = new double* [_size];
    for (int i = 0; i < _size; ++i) {
        _M[i] = new double [_size];
        for (int j = 0; j < _size; ++j) {
            _M[i][j] = m._M[i][j];
        }
    }
}
 
void Matrix::destroy()
{
    for (int i = 0; i < _size; ++i) {
        delete[] _M[i];
    }
    delete[] _M;
}
 
std::ostream& operator<< (std::ostream& os, const Matrix& m)
{
    DWORD dwtimestart = GetTickCount();
    int N = m.size();
    for (int i = 0; i < N - 1; ++i) {
        os << "|";
        for (int j = 0; j < N; ++j) {
            os << " " << std::setprecision(6) << std::setw(10) << m(i, j);
        }
        os << "|\n";
    }
    os << "|";
    for (int j = 0; j < N; ++j) {
        os << " " << std::setprecision(6) << std::setw(10) << m(N - 1, j);
    }
    DWORD dwtimeEnd = GetTickCount();
    std::cout << "time\t" << dwtimeEnd - dwtimestart << "\n" << "N\t" << N << "\n";
    return os << "|";
}
 
// равномерно-распределённая на [0, 1] величина
double drand()
{
    return std::rand() / (double)RAND_MAX;
}
 
Matrix randomMatrix(int size, double M)
{
    Matrix m(size);
    for (int i = 0; i < size; ++i) {
        //m(i, i) = drand() * M;
        for (int j = i; j < size; ++j) {
            m(i, j) = drand() * M;
            m(j, i) = m(i, j);
        }
    }
    return m;
}
Вот Вам класс для работы с матрицами. Ну а остальное - дело техники
 
Текущее время: 02:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru