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

Объектно-ориентированное программирование - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Шифр TEA http://www.cyberforum.ru/cpp-beginners/thread294191.html
Привет всем, помогите написать блочный шифр под названием TEA =) я сам нуб в этом деле, а как я понял он пишется в несколько строк...долго времени не займет И написать нужно на СИ, только без...
C++ Даны два целых числа Даны два целых числа: D (день) и M (месяц), определяющие правильную дату не високосного года. Вывести значения D и M для даты, предшествующей указанной. #include <iostream> #include <stdio.h> ... http://www.cyberforum.ru/cpp-beginners/thread294185.html
C++ Необходимо передать прогу под с++ срочно!
Привет Всем!! Очень нужна ваша помощ, необходимо в короткие сроки, программу по Реализации симплекс метода в случае положительных свободных членов с Borland Pascal 7.0 на с++!!! Добавлено через 1...
C++ Одномерный и двумерный массив
Даны действительные числа a1,a2,…,an. Вводить их нужно как одномерный массив размером в 8 членов. Из этого массива необходимо составить вот такую матрицу: Ссылка на картинку У меня получилось...
C++ Сортировка вектора с демонстрационной диаграммой. Сравнить различные алгоритмы сортировок по количеству операций. http://www.cyberforum.ru/cpp-beginners/thread294146.html
Сортировка вектора.
C++ Непонятки с fread Добрый день. Столкнулся с такой проблемой: читаю обычный текстовый файл, однако помимо его содержания мне выдает еще ==**** в конце (причем количество = равно количеству переносов строк). Делал и с... подробнее

Показать сообщение отдельно
lemegeton
2925 / 1354 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
13.05.2011, 01:06
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
#include <cassert>
 
class Matrix {
 public:
  Matrix() : rows_(0), cols_(0), data_(NULL) {}
  Matrix(int rows, int cols) : rows_(rows), cols_(cols) {
    data_ = new int*[rows_];
    for (size_t i = 0; i < rows_; ++i)
      data_[i] = new int[cols_];
  }
  Matrix(const Matrix &other) : rows_(0), cols_(0), data_(NULL) {
    CopyFrom(other);
  }
  ~Matrix() {
    Clear();
  }
  void CopyFrom(const Matrix &other) {
    Clear();
    rows_ = other.rows_;
    cols_ = other.cols_;
    data_ = new int*[rows_];
    for (size_t i = 0; i < rows_; ++i) {
      data_[i] = new int[cols_];
      for (size_t j = 0; j < cols_; ++j)
        data_[i][j] = other.data_[i][j];
    }
  }
  void Clear() {
    for (size_t i = 0; i < rows_; ++i) delete [] data_[i];
    delete [] data_;
    data_ = NULL;
    cols_ = rows_ = 0;
  }
  void FillRandom() {
    srand(time(NULL));
    for (size_t i = 0; i < rows_; ++i)
      for (size_t j = 0; j < cols_; ++j)
        data_[i][j] = rand() % 100;
  }
  void FillZero() {
    for (size_t i = 0; i < rows_; ++i)
      for (size_t j = 0; j < cols_; ++j)
        data_[i][j] = 0;
  }
  Matrix Transposition() const {
    Matrix result(rows_, cols_);
    for (size_t i = 0; i < rows_; ++i)
      for (size_t j = 0; j < cols_; ++j)
        result[i][j] = data_[j][i];
    return result;
  }
  Matrix Multiply(const Matrix &other) const {
    assert(cols_ == other.rows_);
    Matrix result(rows_, other.cols_);
    result.FillZero();
    for (size_t i = 0; i < rows_; ++i)
      for (size_t j = 0; j < other.cols_; ++j)
        for (size_t k = 0; k < cols_; ++k)
          result[i][j] += data_[i][k] * other.data_[k][j];
    return result;
  }
  size_t Cols() const { return cols_; }
  size_t Rows() const { return rows_; }
  int At(int i, int j) const {
    return data_[i][j];
  }
  int *operator[](int n) {
    return data_[n];
  }
  Matrix &operator=(const Matrix &other) {
    if (&other == this) return *this;
    CopyFrom(other);
    return *this;
  }
  bool operator==(const Matrix &other) {
    if (cols_ != other.Cols() || rows_ != other.Rows())
      return false;
    for (size_t i = 0; i < rows_; ++i)
      for (size_t j = 0; j < cols_; ++j)
        if (data_[i][j] != other.At(i, j))
          return false;
    return true;
  }
  Matrix operator+(const Matrix &other) {
    assert(cols_ == other.Cols() && rows_ == other.Rows());
    Matrix result(rows_, cols_);
    result.FillZero();
    for (size_t i = 0; i < rows_; ++i)
      for (size_t j = 0; j < cols_; ++j)
        result[i][j] = data_[i][j] + other.data_[i][j];
    return result;
  }
  Matrix operator-(const Matrix &other) {
    assert(cols_ == other.Cols() && rows_ == other.Rows());
    Matrix result(rows_, cols_);
    result.FillZero();
    for (size_t i = 0; i < rows_; ++i)
      for (size_t j = 0; j < cols_; ++j)
        result[i][j] = data_[i][j] - other.data_[i][j];
    return result;
  }
  Matrix operator*(int number) const {
    Matrix result(rows_, cols_);
    result.FillZero();
    for (size_t i = 0; i < rows_; ++i)
      for (size_t j = 0; j < cols_; ++j)
        result[i][j] = data_[i][j] * number;
    return result;
  }
  Matrix operator*(const Matrix &other) {
    return Multiply(other);
  }
  friend std::ostream &operator<<(std::ostream& o, const Matrix &matrix) {
    for (size_t i = 0; i < matrix.rows_; ++i) {
      for (size_t j = 0; j < matrix.cols_; ++j)
        o << " " << matrix.At(i, j);
      o << std::endl;
    }
    return o;
  }
 private:
  size_t rows_;
  size_t cols_;
  int **data_;
};
 
int main(int argc, char *argv[]) {
  Matrix a(3, 5), b(5, 3);
  a.FillRandom();
  b.FillRandom();
  a = a * 2 + a - a;
  Matrix c = a * b;
  std::cout << a << "x" << std::endl << b << "=" << std::endl 
            << c  << std::endl
            << ((c == (a * b)) ? "c == a * b" : "c != a * b") << std::endl;
  return 0;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru