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

Класс матриц - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Функция расчета коэффициента заполнения http://www.cyberforum.ru/cpp-beginners/thread295588.html
Всем здравствуйте. Условие: написать функцию расчета коэффициента заполнения хэш-таблицы ( альфа=n/m - число хранимых элементов /размер массива хэш). Ну, насколько я понял, это нужно разделить кол-во элементов на результат этой функции. int Object::HashFunction( static int key,int size,int p) { double A=(sqrt((double)5) - 1)/2; double z=A*(key+p); z-=(int)z; return...
C++ Отключение предупреждений без "pragma warning" есть ли альтернативная функция или команда для # pragma warning(disable:....); которая отключает предупреждения http://www.cyberforum.ru/cpp-beginners/thread295587.html
Индексация C++
Помогите разобраться. Нужно написать программу на C++, осуществляющую создание индексированного файла с данными о студентах (пусть их будет 5): номер по журналу, ФИО, телефон. Записать данные в файл - не проблема. Данные о студентах можно представить в виде структуры. А как быть с индексацией?
Шаблонное дерево. Длиннейший путь. C++
Здравствуйте. Нужно написать метод, который бы возвращал длиннейший путь в шаблонном дереве в виде динамического массива элементов(путь от корня к листу). Не знаю как написать. Вроде бы по логике надо бы узнать какое поддерево больше и его вернуть, но не знаю как это написать и не уверен, что это правильно. Надеюсь поможите. Вот сам класс, на всякий случай. #pragma once #include <iostream>...
C++ stringrid http://www.cyberforum.ru/cpp-beginners/thread295543.html
нужно загрузить текстовый файл в стрингрид, данные в файле: 1;Трафимов.Н.С;12345; 2;Рожков.К.Н;134235; . . . 12 проблема в том что у меня невыводит первую и последние 4 строчки Добавлено через 5 минут
C++ Перегрузка оператора ввода, ошибка struct date_of_birth { int year; int month; int day; date_of_birth(int year =0, int month =0, int day =0):year(year), month(month) ,day(day){} date_of_birth(const date_of_birth &a):year(a.year), month(a.month) ,day(a.day){} friend std::ostream &operator << (std::ostream &out,const date_of_birth &a) { out <<" year :" <<a.year подробнее

Показать сообщение отдельно
dota
3 / 3 / 0
Регистрация: 20.09.2010
Сообщений: 100
14.05.2011, 19:45     Класс матриц
Задание звучит так : разработать класс для работы с матрицами 2х2 . Прога написана , отлично работает.
Осталось реализовать одну функцию - возведение матрицы в степень . Если будет время и желание , посмотрите плиз . Заранее благодарен
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
#include <iostream.h>
#include <math.h>
#include <string.h>
#include <stdio.h>
#include <windows.h>
 
// Описание класса для работы с квадратными матрицами порядка 2
class matrix {
private: float mData[4];
public:  matrix() {for (int i=0;i<4;i++) mData[i]=0;};
                 matrix(float el1,float el2,float el3,float el4) {mData[0]=el1; mData[1]=el2; mData[2]=el3;mData[3]=el4;};
                 float getel1() {return mData[0];};
                 float getel2() {return mData[1];};
                 float getel3() {return mData[2];};
                 float getel4() {return mData[3];};
 
                 void print() {cout<<mData[0]<<"\t"<<mData[1]<<"\n"<<mData[2]<<"\t"<<mData[3]<<endl;}            
                 
                 bool operator ==(const matrix &m) 
                 {if ((mData[0]==m.mData[0])&&(mData[1]==m.mData[1])&&(mData[2]==m.mData[2])&&(mData[3]==m.mData[3])) 
                         return true; return false;};
                 bool operator !=(const matrix &m) 
                 {if ((mData[0]==m.mData[0])&&(mData[1]==m.mData[1])&&(mData[2]==m.mData[2])&&(mData[3]==m.mData[3])) 
                         return false; return true;};
                 matrix  operator + (const matrix &m) 
                                {float d[4]; for (int i=0;i<4;i++) d[i]=mData[i]+m.mData[i]; matrix res(d[0],d[1],d[2],d[3]); return res;};
                 matrix  operator - (const matrix &m) 
                                {float d[4]; for (int i=0;i<4;i++) d[i]=mData[i]-m.mData[i]; matrix res(d[0],d[1],d[2],d[3]); return res;};
                 matrix  operator * (float f) 
                                {float d[4]; for (int i=0;i<4;i++) d[i]=mData[i]*f; matrix res(d[0],d[1],d[2],d[3]); return res;};
                 matrix operator * (const matrix &m)
                                {float d[4];for(int i=0;i<4;i++){
                d[0]=mData[0]*m.mData[0]+mData[1]*m.mData[2];
                d[1]=mData[0]*m.mData[1]+mData[1]*m.mData[3];
                d[2]=mData[2]*m.mData[0]+mData[3]*m.mData[2];
                d[3]=mData[2]*m.mData[1]+mData[3]*m.mData[3];}
                 matrix res(d[0],d[1],d[2],d[3]); return res;}
 
                 void Transponirovanie() { cout<<mData[0]<<"\t"<<mData[2]<<"\n"<<mData[1]<<"\t"<<mData[3]<<endl;}
                 void Obratnaya() { float q,r;
                        r=mData[0]*mData[3]-mData[1]*mData[2];
                        if(r==0) {cout<<"Obratnoi matrici ne sushestvuet"<<endl;}
                        else {q=1/r;
                 float d[4];for(int i=0;i<4;i++) 
                 {      d[0]=q*mData[3];
                        d[1]=(-1)*q*mData[1];
                        d[2]=(-1)*q*mData[2];
                        d[3]=q*mData[0];}
                        matrix res(d[0],d[1],d[2],d[3]); 
                        cout<<d[0]<<"\t"<<d[1]<<"\n"<<d[2]<<"\t"<<d[3]<<endl;}
                 };
                 void Determinant() { float det; det=mData[0]*mData[3]-mData[1]*mData[2]; cout<<"Determinant raven"<<"\t"<<det<<endl; } 
                 void Sled() { float sl; sl=mData[0]+mData[3]; cout<<"Sled raven"<<"\t"<<sl<<endl; }
};
 
 
int menu();
matrix vvod(int number);
 
int menu() //Функция вывода меню. Возвращает ответ пользователя.
{char buf[10];
int option;
do {
puts("============================");
puts("1-Summa matric");
puts("2-Raznost matric");
puts("3-Umnojenie matrici na skalyar");
puts("4-Transponirovanie matrici");
puts("5-Nahojdenie obratnoi matrici");
puts("6-Umnojenie matric");
puts("7-Opredelitel matrici");
puts("8-Sled matrici");
puts("9-Exit");
puts("============================");
cin>>buf;
option=atoi(buf);}
while (!option); 
return option;
}
 
matrix vvod(int number){
        float e[4];
        cout<<"Vevedite matricu nomer"<<number<<endl;
        for(int i=0;i<4;i++) { cin>>e[i];}
matrix res(e[0],e[1],e[2],e[3]);
return res;
}
 
 
    
int main()         // Главная функция
{
        matrix a;
        matrix b;
        matrix c;
        float f;
        while (true){
switch (menu()){
case 1: system("cls");a=vvod(1);b=vvod(2); c=a+b;cout<<"Rezultat"<<"\n";c.print(); cout<<endl;break;
case 2: system("cls");a=vvod(1);b=vvod(2); c=a-b;cout<<"Rezultat"<<"\n";c.print(); cout<<endl;break;
case 3: system("cls");a=vvod(1);cout<<"vvedite skalyar";cin>>f; c=a*f;cout<<"Rezultat"<<"\n";c.print(); cout<<endl;break;
case 4: system("cls");a=vvod(1);cout<<"Rezultat"<<"\n";a.Transponirovanie();break;
case 5: system("cls");a=vvod(1);cout<<"Rezultat"<<"\n";a.Obratnaya();break;
case 6: system("cls");a=vvod(1);b=vvod(2); c=a*b;cout<<"Rezultat"<<"\n";c.print(); cout<<endl;break;
case 7: system("cls");a=vvod(1);a.Determinant();break;
case 8: system("cls");a=vvod(1);a.Sled();break;
case 9: return 0;
default: cout<<"Takoi optii net"<<endl;
}};
 
        return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru