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

Рассчитать элементы квадратной матрицы по заданной формуле. - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 4.85
NachMed
0 / 0 / 0
Регистрация: 17.07.2012
Сообщений: 31
17.07.2012, 09:44     Рассчитать элементы квадратной матрицы по заданной формуле. #1
Помогите пожалуйста написать программу на С++. Большое Спасибо!

1) рассчитать элементы квадратной матрицы A = (aij ), i,j = 0,1,2,...,n-1 по заданной формуле;
2) сформировать из матрицы A элементы вектора X = (xi), i = 0,1,2,...,n-1 по заданному правилу;
3) провести заданное упорядочение элементов матрицы А или вектора Х.

1) Aij=(pow(j,1/i)+pow(i,1/j))/sqrt(i*j)
2) xi – среднеарифметическое значение положительных элементов i-й строки;
3) упорядочить элементы побочной диагонали матрицы А по убыванию абсолютных значе-ний;
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.07.2012, 09:44     Рассчитать элементы квадратной матрицы по заданной формуле.
Посмотрите здесь:

Вычисление следа заданной матрицы по формуле (Язык Си) C++
Рассчитать элементы массива по формуле C++
Рассчитать элементы квадратной матрицы по заданной формуле C++
C++ Функция симметрично отображает элементы заданной квадратной матрицы
C++ Написать и протестировать подпрограмму, которая переставляет в обратном порядке элементы главной диагонали квадратной матрицы - вывод всей матрицы
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
edward_jonson
 Аватар для edward_jonson
157 / 157 / 25
Регистрация: 23.02.2011
Сообщений: 388
17.07.2012, 17:04     Рассчитать элементы квадратной матрицы по заданной формуле. #2
Для формирования матрицы А брал индексы i+1, j+1, т.к. если брать с нуля, то происходит деление на 0.
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
#include <iostream>
#include <cmath>
#include <iomanip>
 
using namespace std;
 
const int N = 8;
int main()
{
    cout << "Creating matrix A:" << endl;
    double A[N][N] = {0};
 
    for(int i = 0; i < N; i ++)
    {
        for(int j = 0; j < N; j ++)
        {
            A[i][j] = ( pow((double)j+1,(double)1/(i+1)) + pow((double)i+1,(double)1/(j+1)) ) / sqrt((double)((i+1)*(j+1)));
            cout << setw(9) << A[i][j];
        }
        cout << endl;
    }
 
    cout << endl << endl;
 
    cout << "Creating array X:" << endl;
    double X[N];
    for (int i = 0; i < N; i ++)
    {
        double sumPos = 0.0;
        int countPos = 0;
        for(int j = 0; j < N; j ++)
        {
            if(A[i][j] > 0)
            {
                countPos ++;
                sumPos += A[i][j];
            }
        }
        X[i] = sumPos / (double)countPos;
        cout << setw(9) << X[i];
    }
 
    cout << endl << endl;
 
    cout << "Sorting array X:" << endl;
    for (int i = 0; i < N; i ++)
        for (int j = 0; j < N - i - 1; j ++)
            if ( fabs(X[j]) < fabs(X[j+1]) )
            {
                double swap = X[j];
                X[j] = X[j+1];
                X[j+1] = swap;
            }
    for (int i = 0; i < N; i ++) cout << setw(9) << X[i];
 
    cout << endl << endl;
 
    return 0;
}
NachMed
0 / 0 / 0
Регистрация: 17.07.2012
Сообщений: 31
17.07.2012, 18:43  [ТС]     Рассчитать элементы квадратной матрицы по заданной формуле. #3
Цитата Сообщение от edward_jonson Посмотреть сообщение
Для формирования матрицы А брал индексы i+1, j+1, т.к. если брать с нуля, то происходит деление на 0.
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
#include <iostream>
#include <cmath>
#include <iomanip>
 
using namespace std;
 
const int N = 8;
int main()
{
    cout << "Creating matrix A:" << endl;
    double A[N][N] = {0};
 
    for(int i = 0; i < N; i ++)
    {
        for(int j = 0; j < N; j ++)
        {
            A[i][j] = ( pow((double)j+1,(double)1/(i+1)) + pow((double)i+1,(double)1/(j+1)) ) / sqrt((double)((i+1)*(j+1)));
            cout << setw(9) << A[i][j];
        }
        cout << endl;
    }
 
    cout << endl << endl;
 
    cout << "Creating array X:" << endl;
    double X[N];
    for (int i = 0; i < N; i ++)
    {
        double sumPos = 0.0;
        int countPos = 0;
        for(int j = 0; j < N; j ++)
        {
            if(A[i][j] > 0)
            {
                countPos ++;
                sumPos += A[i][j];
            }
        }
        X[i] = sumPos / (double)countPos;
        cout << setw(9) << X[i];
    }
 
    cout << endl << endl;
 
    cout << "Sorting array X:" << endl;
    for (int i = 0; i < N; i ++)
        for (int j = 0; j < N - i - 1; j ++)
            if ( fabs(X[j]) < fabs(X[j+1]) )
            {
                double swap = X[j];
                X[j] = X[j+1];
                X[j+1] = swap;
            }
    for (int i = 0; i < N; i ++) cout << setw(9) << X[i];
 
    cout << endl << endl;
 
    return 0;
}
Не знаю даже как благодарить))). А если вводить размерность матрицы, тогда надо написать вместо "const int N = 8" это "cin>>N" только уже в main?

Добавлено через 14 минут
Цитата Сообщение от edward_jonson Посмотреть сообщение
Для формирования матрицы А брал индексы i+1, j+1, т.к. если брать с нуля, то происходит деление на 0.
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
#include <iostream>
#include <cmath>
#include <iomanip>
 
using namespace std;
 
const int N = 8;
int main()
{
    cout << "Creating matrix A:" << endl;
    double A[N][N] = {0};
 
    for(int i = 0; i < N; i ++)
    {
        for(int j = 0; j < N; j ++)
        {
            A[i][j] = ( pow((double)j+1,(double)1/(i+1)) + pow((double)i+1,(double)1/(j+1)) ) / sqrt((double)((i+1)*(j+1)));
            cout << setw(9) << A[i][j];
        }
        cout << endl;
    }
 
    cout << endl << endl;
 
    cout << "Creating array X:" << endl;
    double X[N];
    for (int i = 0; i < N; i ++)
    {
        double sumPos = 0.0;
        int countPos = 0;
        for(int j = 0; j < N; j ++)
        {
            if(A[i][j] > 0)
            {
                countPos ++;
                sumPos += A[i][j];
            }
        }
        X[i] = sumPos / (double)countPos;
        cout << setw(9) << X[i];
    }
 
    cout << endl << endl;
 
    cout << "Sorting array X:" << endl;
    for (int i = 0; i < N; i ++)
        for (int j = 0; j < N - i - 1; j ++)
            if ( fabs(X[j]) < fabs(X[j+1]) )
            {
                double swap = X[j];
                X[j] = X[j+1];
                X[j+1] = swap;
            }
    for (int i = 0; i < N; i ++) cout << setw(9) << X[i];
 
    cout << endl << endl;
 
    return 0;
}
И еще вопросик. Вы сделали упорядочивание вектора, конечно спасибо за это но мне по заданию надо упорядочить побочную диагональ матрицы А по убывынию абсолютных значений.
edward_jonson
 Аватар для edward_jonson
157 / 157 / 25
Регистрация: 23.02.2011
Сообщений: 388
17.07.2012, 21:20     Рассчитать элементы квадратной матрицы по заданной формуле. #4
ну в задании сказано или вектора Х или побочную диагональ матрицы А сейчас сделаем (+ чтобы с клавиатуры вводить размерность). Диагональ сортировать проще переписав её в уже ненужный нам вектор Х, а сортировку его оставить на месте, и потом обратно переписать его в матрицу
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
#include <iostream>
#include <cmath>
#include <iomanip>
 
using namespace std;
 
int main()
{
    int N;
    cout << "Enter size of matrix A:" << endl;
    cin >> N;
    cout << "Creating matrix A:" << endl;
    // Создаётся матрица A
    double **A = new double* [N];
    for(int i = 0; i < N; i ++) A[i] = new double [N];
 
    for(int i = 0; i < N; i ++)
    {
        for(int j = 0; j < N; j ++)
        {
            A[i][j] = ( pow((double)j+1,(double)1/(i+1)) + pow((double)i+1,(double)1/(j+1)) ) / sqrt((double)((i+1)*(j+1)));
            cout << setw(9) << A[i][j];
        }
        cout << endl;
    }
 
    cout << endl << endl;
 
    cout << "Creating array X:" << endl;
    // Создаётся вектор X
    double *X = new double [N];
    for (int i = 0; i < N; i ++)
    {
        double sumPos = 0.0;
        int countPos = 0;
        for(int j = 0; j < N; j ++)
        {
            if(A[i][j] > 0)
            {
                countPos ++;
                sumPos += A[i][j];
            }
        }
        X[i] = sumPos / (double)countPos;
        cout << setw(9) << X[i];
    }
 
    cout << endl << endl;
 
    cout << "Sorting principal diagonal of matrix A:" << endl;
    // Побочная диагональ матрицы А переписывается в вектор X
    for (int i = 0; i < N; i ++)
        X[i] = A[i][N-i-1];
    // Вектор Х сортируется по убыванию
    for (int i = 0; i < N; i ++)
        for (int j = 0; j < N - i - 1; j ++)
            if ( fabs(X[j]) < fabs(X[j+1]) )
            {
                double swap = X[j];
                X[j] = X[j+1];
                X[j+1] = swap;
            }
    // Вектор Х переписывается в побочную диагональ матрицы А
    for (int i = 0; i < N; i ++)
        A[i][N-i-1] = X[i];
    // Вывод матрицы А
    for (int i = 0; i < N; i ++)
    {
        for (int j = 0; j < N; j ++)
            cout << setw(9) << A[i][j];
        cout << endl;
    }
 
    cout << endl << endl;
    // Освобождение памяти
    for (int i = 0; i < N; i ++) delete [] A[i];
    delete [] A;
    delete [] X;
 
    return 0;
}
NachMed
0 / 0 / 0
Регистрация: 17.07.2012
Сообщений: 31
17.07.2012, 22:25  [ТС]     Рассчитать элементы квадратной матрицы по заданной формуле. #5
Цитата Сообщение от edward_jonson Посмотреть сообщение
ну в задании сказано или вектора Х или побочную диагональ матрицы А сейчас сделаем (+ чтобы с клавиатуры вводить размерность). Диагональ сортировать проще переписав её в уже ненужный нам вектор Х, а сортировку его оставить на месте, и потом обратно переписать его в матрицу
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
#include <iostream>
#include <cmath>
#include <iomanip>
 
using namespace std;
 
int main()
{
    int N;
    cout << "Enter size of matrix A:" << endl;
    cin >> N;
    cout << "Creating matrix A:" << endl;
    // Создаётся матрица A
    double **A = new double* [N];
    for(int i = 0; i < N; i ++) A[i] = new double [N];
 
    for(int i = 0; i < N; i ++)
    {
        for(int j = 0; j < N; j ++)
        {
            A[i][j] = ( pow((double)j+1,(double)1/(i+1)) + pow((double)i+1,(double)1/(j+1)) ) / sqrt((double)((i+1)*(j+1)));
            cout << setw(9) << A[i][j];
        }
        cout << endl;
    }
 
    cout << endl << endl;
 
    cout << "Creating array X:" << endl;
    // Создаётся вектор X
    double *X = new double [N];
    for (int i = 0; i < N; i ++)
    {
        double sumPos = 0.0;
        int countPos = 0;
        for(int j = 0; j < N; j ++)
        {
            if(A[i][j] > 0)
            {
                countPos ++;
                sumPos += A[i][j];
            }
        }
        X[i] = sumPos / (double)countPos;
        cout << setw(9) << X[i];
    }
 
    cout << endl << endl;
 
    cout << "Sorting principal diagonal of matrix A:" << endl;
    // Побочная диагональ матрицы А переписывается в вектор X
    for (int i = 0; i < N; i ++)
        X[i] = A[i][N-i-1];
    // Вектор Х сортируется по убыванию
    for (int i = 0; i < N; i ++)
        for (int j = 0; j < N - i - 1; j ++)
            if ( fabs(X[j]) < fabs(X[j+1]) )
            {
                double swap = X[j];
                X[j] = X[j+1];
                X[j+1] = swap;
            }
    // Вектор Х переписывается в побочную диагональ матрицы А
    for (int i = 0; i < N; i ++)
        A[i][N-i-1] = X[i];
    // Вывод матрицы А
    for (int i = 0; i < N; i ++)
    {
        for (int j = 0; j < N; j ++)
            cout << setw(9) << A[i][j];
        cout << endl;
    }
 
    cout << endl << endl;
    // Освобождение памяти
    for (int i = 0; i < N; i ++) delete [] A[i];
    delete [] A;
    delete [] X;
 
    return 0;
}
Ты гений))) Классно с динамическим массивом сделал))) Респект тебе и уважуха!!!

Добавлено через 14 минут
edward_jonson,
Добрый гений извини если напрягаю тебя, сможешь посмотреть еще одну задачку с массивами? Она последняя в моей контрольной работе, ее доделаю и отвяжусь от программирования, начну спокойно заниматься Гидравликой. Я учусь на инженера прибориста, поэтому сильно в программирование не углубляюсь, не думаю что оно мне сильно пригодится, больше занимаюсь Теорией автоматического управления. Поможешь с задачкой?
edward_jonson
 Аватар для edward_jonson
157 / 157 / 25
Регистрация: 23.02.2011
Сообщений: 388
17.07.2012, 23:53     Рассчитать элементы квадратной матрицы по заданной формуле. #6
Ну напиши её, а там посмотрим)
NachMed
0 / 0 / 0
Регистрация: 17.07.2012
Сообщений: 31
18.07.2012, 10:51  [ТС]     Рассчитать элементы квадратной матрицы по заданной формуле. #7
Цитата Сообщение от edward_jonson Посмотреть сообщение
Ну напиши её, а там посмотрим)
1. С помощью динамического выделения памяти создать двухмерный массив размерно-стью m x n элементов указанного типа данных. Размерность массива вводить с клавиатуры.
2. Для выделения и освобождения памяти воспользоваться операторами new и delete.
3. Заполнить массив случайными значениями в заданном диапазоне.
4. Вывести на экран значения элементов массива в виде таблицы.
5. Вычислить сумму значений элементов указанного объекта с номером номер. Вывести на экран значения элементов и полученную сумму.
6. При выполнении операций заполнения массива значениями и вывода значений на экран необходимо использовать оператор цикла, указанный в задании.

Размерность:MxN
Тип данных: Char
Диапазон значений: 50-100
Оператор цикла: for
Объект: Строка
Номер: 1


Заранее благодарен!
edward_jonson
 Аватар для edward_jonson
157 / 157 / 25
Регистрация: 23.02.2011
Сообщений: 388
18.07.2012, 15:34     Рассчитать элементы квадратной матрицы по заданной формуле. #8
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
#include <iostream>
#include <cstdlib>
#include <iomanip>
#include <ctime>
using namespace std;
 
int main()
{
    int m, n;
    cout << "Enter m, n:" << endl;
    cin >> m >> n;
 
    cout << endl << "Matrix:" << endl << endl;
    char ** matrix = new char* [m];
    for (int i = 0; i < m; i ++) matrix[i] = new char [n];
 
    srand(time(NULL));
    for (int i = 0; i < m; i ++)
    {
        for (int j = 0; j < n; j ++)
        {
            matrix[i][j] = rand()%51 + 50;
            cout << setw(5) <<(int)matrix[i][j];
        }
        cout << endl;
    }
 
    cout << endl << endl;
 
    int sum = 0;
    int numbOfStr = 0;
    cout << "Elements of " << numbOfStr + 1 << " string to sum:" << endl << endl;
    for (int j = 0; j < n; j ++)
    {
        sum += (int)matrix[numbOfStr][j];
        cout << setw(5) << (int)matrix[numbOfStr][j];
    }
 
    cout << endl <<endl;
 
    cout << "Sum of elements of " << numbOfStr + 1 << " string = " << (int)sum << endl;
 
    for (int i = 0; i < m; i ++) delete [] matrix[i];
    delete [] matrix;
 
    return 0;
}
Довольно странно использовать тип char для действий с целыми числами, поэтому приходится везде делать приведение типа к int
NachMed
0 / 0 / 0
Регистрация: 17.07.2012
Сообщений: 31
18.07.2012, 21:03  [ТС]     Рассчитать элементы квадратной матрицы по заданной формуле. #9
Спасибо огромное!!! В реальной жизни помог бы чем смог тебе Действительно странно почему в задании char, я сам начал было переделывать прошлую работу, которую тоже ты мне сделал и зашел в тупик с этим char, не знал как его применить с целыми числами. Возможно преподавательница ошиблась, она молодая в прошлом году наш универ закончила УГНТУ, теперь начала преподавать, похоже что она путается т.к. не достаточно опыта. Но ты красиво выкрутился, даже если она ошиблась не страшно твоя программа работает и пусть даже по заданию char, ты в программе этот тип поставил и она работает Ты гениально решаешь эти задачки, наверное университет на программера закончил и сейчас работаешь программистом в какой нибудь крупной компании

Добавлено через 1 час 43 минуты
edward_jonson,
Извини за мою наглость, но если время у тебя есть ты не мог бы проверить мою задачку т.е. правильно решена или нет. Сначала условие напишу, ниже код решения.

1. Создать класс, описывающий указанную в задании сущность и включающий не менее 4 - 5 полей (места, время, стоимость, . . . ), в том числе наименование объекта.
2. Разработать набор 4 - 5 методов, которые служат для обработки данных – обязательно включить в набор методы для ввода значений с клавиатуры, вывода на экран.
3. Создать в программе несколько переменных (объектов) с типом указанного класса и продемонстрировать работу методов класса.

Мой вариант: Автостоянка (места, время, стоимость, . . . )

Решение:
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
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
#include "stdafx.h"
#include <cstdlib
#include <iostream>
#include <windows.h>
#include <conio.h>
#include <fstream>
#include <iomanip>
#include <string.h>
 
using namespace std;
 
const int L=32;
const int N=128;
 
 
struct date // структура даты
{ 
  int day;
  char month[4]; 
  int year;
};
 
struct times // структура времени
{ 
  int hour;
  int minute; 
};
 
struct parking // общая структура
{   
    int places; // место
    times t; // время типа times
    char car[L];    // машина 
    char fio[L];    // фио сотрудника
    date d; // время типа date
};
 
 
 
class mas_parking // класс парковки
{   private:
        parking x[N]; // массив типа parking
        int n;
    public:
        mas_parking () {
                        n=0;                        
                      }        
        void input_File (); // метод для ввода информации из файла
        void output (); // вывод на экран
        void add_Person (); // добавление машины
        void sort_car (); // сортировка по полю машина
        void output_file ();  //  сохранение информации в файле
};
 
 
void mas_parking::input_File () 
{    ifstream fin;
     char file[L], iniz [5];
     n=0;
     cout << " Введите имя входного файла: ";
     cin >> file; // вводим название входного файла
     strcat(file,".txt");     
     fin.open (file);
     if (fin.fail ()) {  // проверяем на удачное открытие
                        cout <<" "<< file << " Не удалось открыть\n";                        
                        return;
                      }
     do {   fin >> x[n].places >> x[n].t.hour >> x[n].t.minute >> x[n].car >> x[n].fio >> iniz >> x[n].d.day >> x[n].d.month >> x[n].d.year; // вводим в массив x информацию
            strcat (x[n].fio, " "); // склеиванем fio и пробел, результат заносим в fio
            strcat (x[n].fio, iniz);   // склеиванем fio и iniz, результат заносим в fio
            n++;
        } while (fin.good());  // делаем до конца файла                           
     fin.close ();
     cout<<" Файл открыт\n";     
}
 
void mas_parking::output ()
{
    int i;
    cout << left;
    cout << "  ==============================================================================================\n";
    cout << "  |    |         |     Время     |               |                       |      Дата оплаты     |\n";
    cout << "  | №  |  Место  |===============|     Машина    |      ФИО водителя     |======================|\n";
    cout << "  |    | (номер) | Часы | Минуты |               |                       | День | Месяц |  Год  |\n";
    cout << "  |====|=========|===============|===============|=======================|======================|\n";
    for (i=0;i<n;i++)
     {
         cout << "  | "<<setw(2)<<i+1<<" | "<< setw(7) << x[i].places <<" | "<< setw(4) << x[i].t.hour <<" | "<< setw(6) << x[i].t.minute <<" | "<< setw(13)<< x[i].car <<" | " << setw(21) << x[i].fio << " | " << setw(4) << x[i].d.day<<" | "  << setw(4) << x[i].d.month<<"  |  "<< setw(5) << x[i].d.year<<"| " << endl; // выводим все поля по очереди
        cout << "  |====|=========|======|========|===============|=======================|======|=======|=======|\n";
 
     }
}
 
void mas_parking::add_Person ()
{   parking t;    
    char iniz[5]; // объявлянием переменную для хранения инициалов (например G.F.) 
    if (n==N) // проверяем есть ли место в массиве
        {   
            cout << " Массив заполнен \n";
            return;
        }             
    cout << " Добавляемая запись: "<<endl;
    // далее поэтапно вводим все поля
    cout << " Место (номер): ";
    cin  >> t.places;
    cout << " Время нахождения (часы): ";
    cin  >> t.t.hour;
    cout << " Время нахождения (минуты): ";
    cin  >> t.t.minute;
    cout << " Автомобиль: ";
    cin  >> t.car;
    cout << " ФИО: ";
    cin  >> t.fio >> iniz;
    strcat (t.fio, " ");
    strcat (t.fio, iniz);
    cout << " Дата (день): ";
    cin  >> t.d.day;
    cout << " Дата (месяц): ";
    cin  >> t.d.month;
    cout << " Дата (год): ";
    cin  >> t.d.year;
    x[n]=t;
    n++;   
    cout << endl;
    cout << " Запись добавлена!\n";
}
 
 
 
void mas_parking::sort_car()
{
    int i, flag, t=n;
    parking  tmp;
 
    do{ flag=0; t--;
        for(i=0;i<t;i++)
        {   if(strcmp(x[i].car,x[i+1].car)>0) // strcmp  - функция сравнения строк , сортировка по алфавиту
            {
                // переставляем местами строки
                tmp=x[i];  
                x[i]=x[i+1];
                x[i+1]=tmp;
                flag=1;
            }
        }
      }while(flag!=0);
}
 
void mas_parking::output_file () // метод вывода массива в файл
{
    ofstream fout;
    char file[L];
    int i;
    cout<<" Введите имя для сохраняемого файла: ";
    cin>>file;
    strcat(file,".txt"); // склеиваем file и .txt , чтобы при вводе названия файла не надо было вводить каждый раз .txt
    fout.open(file);
    if (fout.fail()) // проверяем файл
     {  cout<<file<<" Не удалось сохранить\n";
        getch();
        return;
     }
    for (i = 0; i < n-1; i++) // записываем построчно весь массив x
    {
    fout<< setw(7) << x[i].places
        << setw(4) << x[i].t.hour
        << setw(6) << x[i].t.minute
        << setw(13)<< x[i].car 
        << setw(21)<< x[i].fio
        << setw(4) << x[i].d.day 
        << setw(4) << x[i].d.month
        << setw(5) << x[i].d.year << endl;
     }
    fout<< setw(7) << x[n-1].places // тут записываем последнюю строку, чтобы массив правильно записался без перехода на новую строку
        << setw(4) << x[n-1].t.hour
        << setw(6) << x[n-1].t.minute
        << setw(13)<< x[n-1].car 
        << setw(21)<< x[n-1].fio
        << setw(4) << x[n-1].d.day 
        << setw(4) << x[n-1].d.month
        << setw(5) << x[n-1].d.year;
    
 
fout.close();
cout<<" Файл успешно сохранен\n";
cin.get();
}
 
int main(int argc, char* argv[])
{
    setlocale(LC_ALL,"Russian");
 
    mas_parking a; // переменная a типа mas_parking
    int key; // описали ключ
    while(1) // бесконечный цикл
    {
        system("CLS"); // очистка экрана
        cout << "  === Меню 'Автостоянка' ===" << endl; // далее вывод меню
        cout << " 1. Загрузка данных из файла" << endl;
        cout << " 2. Просмотр файла" << endl;
        cout << " 3. Сортировка по машине" << endl;
        cout << " 4. Добавление записи " << endl;
        cout << " 5. Сохранение в файле " << endl;
        cout << " 6. Выход" << endl;
        cout << endl;
        cout << " Ваш выбор (1-12): ";
        cin>>key;
 
        switch(key) // сам конструктор switch 
        {
            case 1: a.input_File (); // при выборе 1 идет вызов метода input_File
                    cout<<endl<<" "; // переход на новую строку
                    system("PAUSE"); // пауза
                    break;
            case 2: a.output ();
                    cout<<endl<<" ";
                    system("PAUSE");
                    break;
            case 3: a.sort_car();
                    a.output();
                    cout<<endl<<" ";
                    system("PAUSE");
                    break;
            case 4: a.add_Person ();
                    cout<<endl<<" ";
                    system("PAUSE");
                    break;
            case 5: a.output_file ();
                    cout<<endl<<" ";
                    system("PAUSE");
                    break;
            case 6: cout << " Работа закончена!\n";
                    cout<<endl<<" ";
                    system("PAUSE");
                    return 0;
            default: cout << "Нет такого пункта!"<< endl; // если выбрано какое то другое значение не из диапазона 1-6
            cout<<endl<<" ";
            system("PAUSE");
        }
    }
 cin.ignore(cin.rdbuf()->in_avail());
 cin.get();
 return 0;
}
Добавлено через 15 секунд
edward_jonson,
Извини за мою наглость, но если время у тебя есть ты не мог бы проверить мою задачку т.е. правильно решена или нет. Сначала условие напишу, ниже код решения.

1. Создать класс, описывающий указанную в задании сущность и включающий не менее 4 - 5 полей (места, время, стоимость, . . . ), в том числе наименование объекта.
2. Разработать набор 4 - 5 методов, которые служат для обработки данных – обязательно включить в набор методы для ввода значений с клавиатуры, вывода на экран.
3. Создать в программе несколько переменных (объектов) с типом указанного класса и продемонстрировать работу методов класса.

Мой вариант: Автостоянка (места, время, стоимость, . . . )

Решение:
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
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
#include "stdafx.h"
#include <cstdlib
#include <iostream>
#include <windows.h>
#include <conio.h>
#include <fstream>
#include <iomanip>
#include <string.h>
 
using namespace std;
 
const int L=32;
const int N=128;
 
 
struct date // структура даты
{ 
  int day;
  char month[4]; 
  int year;
};
 
struct times // структура времени
{ 
  int hour;
  int minute; 
};
 
struct parking // общая структура
{   
    int places; // место
    times t; // время типа times
    char car[L];    // машина 
    char fio[L];    // фио сотрудника
    date d; // время типа date
};
 
 
 
class mas_parking // класс парковки
{   private:
        parking x[N]; // массив типа parking
        int n;
    public:
        mas_parking () {
                        n=0;                        
                      }        
        void input_File (); // метод для ввода информации из файла
        void output (); // вывод на экран
        void add_Person (); // добавление машины
        void sort_car (); // сортировка по полю машина
        void output_file ();  //  сохранение информации в файле
};
 
 
void mas_parking::input_File () 
{    ifstream fin;
     char file[L], iniz [5];
     n=0;
     cout << " Введите имя входного файла: ";
     cin >> file; // вводим название входного файла
     strcat(file,".txt");     
     fin.open (file);
     if (fin.fail ()) {  // проверяем на удачное открытие
                        cout <<" "<< file << " Не удалось открыть\n";                        
                        return;
                      }
     do {   fin >> x[n].places >> x[n].t.hour >> x[n].t.minute >> x[n].car >> x[n].fio >> iniz >> x[n].d.day >> x[n].d.month >> x[n].d.year; // вводим в массив x информацию
            strcat (x[n].fio, " "); // склеиванем fio и пробел, результат заносим в fio
            strcat (x[n].fio, iniz);   // склеиванем fio и iniz, результат заносим в fio
            n++;
        } while (fin.good());  // делаем до конца файла                           
     fin.close ();
     cout<<" Файл открыт\n";     
}
 
void mas_parking::output ()
{
    int i;
    cout << left;
    cout << "  ==============================================================================================\n";
    cout << "  |    |         |     Время     |               |                       |      Дата оплаты     |\n";
    cout << "  | №  |  Место  |===============|     Машина    |      ФИО водителя     |======================|\n";
    cout << "  |    | (номер) | Часы | Минуты |               |                       | День | Месяц |  Год  |\n";
    cout << "  |====|=========|===============|===============|=======================|======================|\n";
    for (i=0;i<n;i++)
     {
         cout << "  | "<<setw(2)<<i+1<<" | "<< setw(7) << x[i].places <<" | "<< setw(4) << x[i].t.hour <<" | "<< setw(6) << x[i].t.minute <<" | "<< setw(13)<< x[i].car <<" | " << setw(21) << x[i].fio << " | " << setw(4) << x[i].d.day<<" | "  << setw(4) << x[i].d.month<<"  |  "<< setw(5) << x[i].d.year<<"| " << endl; // выводим все поля по очереди
        cout << "  |====|=========|======|========|===============|=======================|======|=======|=======|\n";
 
     }
}
 
void mas_parking::add_Person ()
{   parking t;    
    char iniz[5]; // объявлянием переменную для хранения инициалов (например G.F.) 
    if (n==N) // проверяем есть ли место в массиве
        {   
            cout << " Массив заполнен \n";
            return;
        }             
    cout << " Добавляемая запись: "<<endl;
    // далее поэтапно вводим все поля
    cout << " Место (номер): ";
    cin  >> t.places;
    cout << " Время нахождения (часы): ";
    cin  >> t.t.hour;
    cout << " Время нахождения (минуты): ";
    cin  >> t.t.minute;
    cout << " Автомобиль: ";
    cin  >> t.car;
    cout << " ФИО: ";
    cin  >> t.fio >> iniz;
    strcat (t.fio, " ");
    strcat (t.fio, iniz);
    cout << " Дата (день): ";
    cin  >> t.d.day;
    cout << " Дата (месяц): ";
    cin  >> t.d.month;
    cout << " Дата (год): ";
    cin  >> t.d.year;
    x[n]=t;
    n++;   
    cout << endl;
    cout << " Запись добавлена!\n";
}
 
 
 
void mas_parking::sort_car()
{
    int i, flag, t=n;
    parking  tmp;
 
    do{ flag=0; t--;
        for(i=0;i<t;i++)
        {   if(strcmp(x[i].car,x[i+1].car)>0) // strcmp  - функция сравнения строк , сортировка по алфавиту
            {
                // переставляем местами строки
                tmp=x[i];  
                x[i]=x[i+1];
                x[i+1]=tmp;
                flag=1;
            }
        }
      }while(flag!=0);
}
 
void mas_parking::output_file () // метод вывода массива в файл
{
    ofstream fout;
    char file[L];
    int i;
    cout<<" Введите имя для сохраняемого файла: ";
    cin>>file;
    strcat(file,".txt"); // склеиваем file и .txt , чтобы при вводе названия файла не надо было вводить каждый раз .txt
    fout.open(file);
    if (fout.fail()) // проверяем файл
     {  cout<<file<<" Не удалось сохранить\n";
        getch();
        return;
     }
    for (i = 0; i < n-1; i++) // записываем построчно весь массив x
    {
    fout<< setw(7) << x[i].places
        << setw(4) << x[i].t.hour
        << setw(6) << x[i].t.minute
        << setw(13)<< x[i].car 
        << setw(21)<< x[i].fio
        << setw(4) << x[i].d.day 
        << setw(4) << x[i].d.month
        << setw(5) << x[i].d.year << endl;
     }
    fout<< setw(7) << x[n-1].places // тут записываем последнюю строку, чтобы массив правильно записался без перехода на новую строку
        << setw(4) << x[n-1].t.hour
        << setw(6) << x[n-1].t.minute
        << setw(13)<< x[n-1].car 
        << setw(21)<< x[n-1].fio
        << setw(4) << x[n-1].d.day 
        << setw(4) << x[n-1].d.month
        << setw(5) << x[n-1].d.year;
    
 
fout.close();
cout<<" Файл успешно сохранен\n";
cin.get();
}
 
int main(int argc, char* argv[])
{
    setlocale(LC_ALL,"Russian");
 
    mas_parking a; // переменная a типа mas_parking
    int key; // описали ключ
    while(1) // бесконечный цикл
    {
        system("CLS"); // очистка экрана
        cout << "  === Меню 'Автостоянка' ===" << endl; // далее вывод меню
        cout << " 1. Загрузка данных из файла" << endl;
        cout << " 2. Просмотр файла" << endl;
        cout << " 3. Сортировка по машине" << endl;
        cout << " 4. Добавление записи " << endl;
        cout << " 5. Сохранение в файле " << endl;
        cout << " 6. Выход" << endl;
        cout << endl;
        cout << " Ваш выбор (1-12): ";
        cin>>key;
 
        switch(key) // сам конструктор switch 
        {
            case 1: a.input_File (); // при выборе 1 идет вызов метода input_File
                    cout<<endl<<" "; // переход на новую строку
                    system("PAUSE"); // пауза
                    break;
            case 2: a.output ();
                    cout<<endl<<" ";
                    system("PAUSE");
                    break;
            case 3: a.sort_car();
                    a.output();
                    cout<<endl<<" ";
                    system("PAUSE");
                    break;
            case 4: a.add_Person ();
                    cout<<endl<<" ";
                    system("PAUSE");
                    break;
            case 5: a.output_file ();
                    cout<<endl<<" ";
                    system("PAUSE");
                    break;
            case 6: cout << " Работа закончена!\n";
                    cout<<endl<<" ";
                    system("PAUSE");
                    return 0;
            default: cout << "Нет такого пункта!"<< endl; // если выбрано какое то другое значение не из диапазона 1-6
            cout<<endl<<" ";
            system("PAUSE");
        }
    }
 cin.ignore(cin.rdbuf()->in_avail());
 cin.get();
 return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.12.2012, 21:51     Рассчитать элементы квадратной матрицы по заданной формуле.
Еще ссылки по теме:

C++ Работа с матрицами (Получить элементы квадратной матрицы, где элементы матрицы зависят от параметров)
C++ Написать программу для преобразования заданной квадратной матрицы...
Для заданной квадратной матрицы сформировать одномерный массив из ее диагональных элементов C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
almaz123
Сообщений: n/a
09.12.2012, 21:51     Рассчитать элементы квадратной матрицы по заданной формуле. #10
edward_jonson , помоги пожалуйста решить и мою задачку.
Миниатюры
Рассчитать элементы квадратной матрицы по заданной формуле.  
Yandex
Объявления
09.12.2012, 21:51     Рассчитать элементы квадратной матрицы по заданной формуле.
Ответ Создать тему
Опции темы

Текущее время: 16:49. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru