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

Вычисления в матрице - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Определить размер заработной платы каждого сотрудника фирмы http://www.cyberforum.ru/cpp-beginners/thread1307454.html
Информация о сотрудниках фирмы содержит: • Ф. И. О. сотрудника; • табельный номер; • количество отработанных часов за месяц; • почасовой тариф. Рабочее время свыше 144 часов считается сверхурочным и оплачивается в двойном размере. Выведите размер заработной платы каждого сотрудника фирмы за вычетом подоходного налога, который составляет 13 % от суммы заработка. Информацию отсортируйте. ...
C++ Из двух папок выбирать по картинке и возвращать каждый раз полный путь к следующей картинке Здравствуйте. Помогите, пожалуйста, с данной проблемой. Даны 2 папки. Нужно написать функцию, которая по очереди из этих папок выбирает по картинке и возвращает каждый раз полный путь к следующей выбираемой картинке. Спасибо за внимание http://www.cyberforum.ru/cpp-beginners/thread1307447.html
Задано действительные числа а0.а30 C++
Задано действительные числа а0....а30 ,б0......б30, с0.......с30 и числа x y z. Посчитать такое ((a0*x^30+a1*x^29+....+a30)^2- (b0*y^30+b1*y^29+...b30))/(c0(x+z)^30+ c1(x+z)29+...c30) #include <iostream> #include <cmath> using namespace std; double f(double *a, double x) { double k = 0; int n; cin >> n; for (int i = 0; i < n; i++)
Классы,Создание потомков класса C++
Помогите доделать программу у меня существует класс из марки, объема, памяти, функции Q=память/цена. Нужно сделать класс-потомок P: количество и функции Qp=Q*P Помогите сделать класс потомок #include <iostream> #include <string.h> #include <stdio.h> using namespace std; class B1 { string name; int nom,sz; float v; public:
C++ Найти области, невидимые для наблюдателя при заданном профиле местности http://www.cyberforum.ru/cpp-beginners/thread1307441.html
2. В одномерном массиве A хранятся значения высот некоторого профиля местности (ее вертикального сечения) с постоянным шагом. Найти области, невидимые для наблюдателя, находящегося в точке А1
C++ Сравнить четыре слова одинаковой длины Даны четыре слова одинаковой длины. Напечатать сообщение о наличии или отсутствии одинаковых слов и это слово. Только пожалуйста, без ЭТО ЭЛЕМЕНТАРНО. подробнее

Показать сообщение отдельно
egor2116
 Аватар для egor2116
337 / 368 / 42
Регистрация: 20.01.2013
Сообщений: 1,113
22.11.2014, 16:07     Вычисления в матрице
Наверное как то так
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
#include <iostream>
 
namespace egor2116x
{
    struct MinElement
    {
        int indexX;
        int indexY;
        int value;  
    };
    
    class Matrix
    {
        private:
            
            int ** array; 
            const size_t SIZE = 4;
            MinElement min;
            
        public: 
        
            Matrix()
            {
                array = new int * [SIZE];
                for(int i = 0; i < SIZE; ++i)
                    array[i] = new int[SIZE];
                
                std::cout << "Input matrix :" << std::endl;
                
                for(int i = 0; i < SIZE; ++i)
                {
                    for(int k = 0; k < SIZE; ++k)
                        std::cin >> array[i][k];
                    
                    std::cout << std::endl;
                }
                
            }
            ~Matrix()
            {
                for(int i = 0; i < SIZE; ++i)
                    delete [] array[i];
                
                delete [] array;
              
            }
            
            int product()
            {
                int prod = 1;
                int count = 0;
                for(int i = 0; i < SIZE; ++i)
                {
                    for(int k = 0; k < SIZE; ++k)
                        if(k == count)
                            prod *= array[i][k];
                    ++count;
                }
                        
                        
                return prod;
            }
            
            int getMin(int numberRow)
            {
                if(numberRow >= SIZE)
                {
                    std::cout << "Incorrect row, row is bigger count rows is matrix" << std::endl;
                    return 1;
                }
                min.indexX = numberRow;
                min.indexY = 0;
                min.value = array[numberRow][0];
                for(int i = 0; i < SIZE; ++i)
                    for(int k = 0; k < SIZE; ++k)
                        if(i == numberRow && min.value > array[i][k])
                        {
                            min.indexX = i;
                            min.indexY = k;
                            min.value = array[i][k];
                        }
                            
                return min.value;
            }
            
            void swap(int & value)
            {
                int temp = value;
                value = min.value;
                array[min.indexX][min.indexY] = temp;
            }
            
            void print()
            {
                for(int i = 0; i < SIZE; ++i)
                {
                    for(int k = 0; k < SIZE; ++k)
                        std::cout << array[i][k] << " ";
                    
                    std::cout << std::endl;
                }
            }
            
    };
}
 
 
int main() {
    
    int row = 3;
    int P = 9999;
    
    egor2116x::Matrix matrix;
    matrix.print();
    
    std::cout << "Product : " << matrix.product() << std::endl;
    std::cout << "Min element in " <<  row << " row : " << matrix.getMin(row) << std::endl;
    matrix.swap(P);
    
    matrix.print();
    
    return 0;
}
 
Текущее время: 08:28. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru