Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/29: Рейтинг темы: голосов - 29, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 10.01.2013
Сообщений: 28

Составить блок-схему алгоритма и написать программу вычисления матричного выражения с использованием подпрограмм

10.01.2013, 12:09. Показов 6374. Ответов 19
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вчера девушка попросила помочь в написании простой программы (у нее курс программирования). Ну я и согласился, ибо сам начал обучение на программиста=)
Есть опыт Паскаля, Дельфи и немного PHP а вот С++ знаю достаточно слабо.(ввод-вывод, функции, элементарные мат.действия). Если кто может - помогите с написанием данной программки. Хоть кодом, хоть советом, хоть идеей)Дело в том, что не могу у себя в голове выстроить четкую картину самого задания)
Оооочень нужно до вечера закончить с этим) Спасибо большое за понимание!

Составить блок-схему алгоритма и написать программу вычисления матричного выражения с использованием подпрограмм. При этом ввод осуществлять с клавиатуры, а вывод на дисплей.
1. Выполнить с помощью подпрограмм не используя глобальных переменных.
2. Размерность массива и элементы массива вводить с клавиатуры. Максимальная размерность массива 8х8.
3. Результаты выводить на экран.
Порядок выполнения работы(по занятиям).
1. Разработка математической модели и блок-схем алгоритмов основного модуля и подпрограмм.
2. Написание и отладка программы.
3. Оформление и защита.

c=(a+b)*a-3*b;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.01.2013, 12:09
Ответы с готовыми решениями:

Составить схему алгоритма и программу вычисления значения функции z с использованием подпрограмм
Составить схему алгоритма и программу вычисления значения функции z с использованием подпрограмм. Вывести значения p,r,z. Вычислить...

Составить схему алгоритма и программу решения задачи вычисления величин z и w с использованием подпрограмм пользователя
ЗАДАНИЕ 2 Составить схему алгоритма и программу решения задачи вычисления величин z и w с использованием подпрограмм пользователя . ...

Составить блок-схему алгоритма и программу вычисления выражения
Составить блок-схему алгоритма и программу вычисления выражения для заданных натурального числа n и действительного числа х. Значение...

19
14 / 14 / 1
Регистрация: 24.03.2012
Сообщений: 238
10.01.2013, 12:14
Что то не очень хорошо понял саму суть задания ) вам нужен простой ввод матрицы с клавиатуры ?) и что за вычисления ?) c=(a+b)*a-3*b просто что значит это не очень понятно)
0
15 / 15 / 11
Регистрация: 06.12.2012
Сообщений: 131
10.01.2013, 12:23
Согласен с ZubSam.
C++
1
2
3
4
5
6
7
8
9
10
for(int i = 0;i < 1;i++){
        double a,b;
        cout<<"Enter a: "; cin>>a;
        cout<<"Enter b: "; cin>>b;
 
        double c = (a+b)*a-3*b;
 
        cout<<"Some c: "<<c<<endl;
        
    }
0
0 / 0 / 0
Регистрация: 10.01.2013
Сообщений: 28
10.01.2013, 12:27  [ТС]
Fareiro, Хахахаха=)
Именно это я написал первым, когда меня попросили=))) Только запаковал в функцию)(глобальных же переменных не должно быть=)

Я и сам понимаю, что c = (a+b)*a-3*b - это из ряда шизофрении....
0
14 / 14 / 1
Регистрация: 24.03.2012
Сообщений: 238
10.01.2013, 12:28
Цитата Сообщение от Fareiro Посмотреть сообщение
for(int i = 0;i < 1;i++)
все хорошо) но зачем Вам цикл ?)
0
123 / 123 / 82
Регистрация: 03.01.2013
Сообщений: 242
10.01.2013, 12:31
может a и b это матрицы, а нада найти матрицу c по уравнению?
0
15 / 15 / 11
Регистрация: 06.12.2012
Сообщений: 131
10.01.2013, 12:35
Цитата Сообщение от ZubSam Посмотреть сообщение
все хорошо) но зачем Вам цикл ?)
Смайл как бы намекает)
0
0 / 0 / 0
Регистрация: 10.01.2013
Сообщений: 28
10.01.2013, 12:38  [ТС]
ntrx, Вам давно говорили, что вы Гений?)))
Думаю, что скорее всего так и есть=)
Fareiro, я Вас понял=))))

Хорошо, а если а и b это и правда матрицы - как организовать такое вот вычисление?
0
123 / 123 / 82
Регистрация: 03.01.2013
Сообщений: 242
10.01.2013, 12:40
создать функцию сложения, вычетания и умножения, и потом просто ввести 2 матрицы, и получить по уравнению
матрицу С
0
0 / 0 / 0
Регистрация: 10.01.2013
Сообщений: 28
10.01.2013, 12:46  [ТС]
ntrx, Можно пример функции сложения, если не сложно?)

Т.е смотрите: Мне нужно создать функцию, локальными переменными которой будут a и b(матрицы), а далее просто сложить их, так? А что потом? как обработать результат одной функции в другой?
0
15 / 15 / 11
Регистрация: 06.12.2012
Сообщений: 131
10.01.2013, 12:51
Матрицы: сложения двух матриц (двумерных массивов)
0
0 / 0 / 0
Регистрация: 10.01.2013
Сообщений: 28
10.01.2013, 12:54  [ТС]
C++
1
2
3
4
5
6
7
8
int summ_function 
{
    int a[8,8], b[8,8], el;
    for ( int i = 0; i< 8; i++) {
         for ( int j = 0; j< 8; j++) {
            cin>>el;
}
}
Добавлено через 1 минуту
Fareiro, А вообще да=) Спасибо=)
Дальше, думаю, смогу разобраться...вот только все же строчка "Не используя глобальные переменные"...

Так странно чувствовать, что ничерта не можешь написать в новом для тебя языке...)
0
 Аватар для Евгений89
102 / 102 / 39
Регистрация: 17.04.2011
Сообщений: 554
10.01.2013, 12:54
обаботать в 3 массиве результат сложения двух других массивом
0
387 / 214 / 102
Регистрация: 09.04.2012
Сообщений: 635
10.01.2013, 12:56
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
#include <stdio.h>
#include <malloc.h>
#include <time.h>
#include <stdlib.h>
 
struct matrix
{
 float **m;
 int sz;
};
 
void print_matrix(struct matrix* k)
{
 int i,j;
 for(i=0;i<k->sz;i++)
 {
  for(j=0;j<k->sz;j++)
   printf("%f ", k->m[i][j]);
  printf("\n");
 }
 printf("\n");
}
 
void sub_matrix(struct matrix* a1, struct matrix* a2, struct matrix* res)
{
 int i,j, s;
 s = a1->sz;
 for(i=0;i<s;i++)
  for(j=0;j<s;j++)
   res->m[i][j] = a1->m[i][j] - a2->m[i][j];
}
 
void add_matrix(struct matrix* a1, struct matrix* a2, struct matrix* res)
{
 int i,j, s;
 s = a1->sz;
 for(i=0;i<s;i++)
  for(j=0;j<s;j++)
   res->m[i][j] = a1->m[i][j] + a2->m[i][j];
}
 
void cmul_matrix(float a1, struct matrix* a2, struct matrix* res)
{
 int i,j, s;
 s = a2->sz;
 for(i=0;i<s;i++)
  for(j=0;j<s;j++)
   res->m[i][j] = a1 * a2->m[i][j];
}
 
void mul_matrix(struct matrix* a1, struct matrix* a2, struct matrix* res)
{
 float y;
 int i,j, k, l, s;
 s = a1->sz;
 y =0.0;
 for(i=0;i<s;i++)
 {
  for(j=0;j<s;j++)
  {
   y = 0.0;
   //res->m[i][j] //a1->m[i][j] //a2->m[i][j];
   for(k=0;k<s;k++)
   {
    y+= a1->m[i][k]*a2->m[k][j];
   }
   res->m[i][j]=y;
  }
 }
}
 
int main()
{
int i,j, n;
struct matrix *A,*B,*C,*E,*tmp,*tmp2,*tmp3;
 
srand(time(0));
n = 5;
 
// Код повторяется, но мне самому хотелось бы узнать
// как передать функции указатель и
// выделить память в функции так, чтобы при выходе из нее
// память сохранилась
 
A = (struct matrix*) malloc(sizeof(struct matrix));
B = (struct matrix*) malloc(sizeof(struct matrix));
C = (struct matrix*) malloc(sizeof(struct matrix));
E = (struct matrix*) malloc(sizeof(struct matrix));
tmp = (struct matrix*) malloc(sizeof(struct matrix));
tmp2 = (struct matrix*) malloc(sizeof(struct matrix));
tmp3 = (struct matrix*) malloc(sizeof(struct matrix));
 
A->m = (float**) malloc(n*sizeof(float*));
B->m = (float**) malloc(n*sizeof(float*));
C->m = (float**) malloc(n*sizeof(float*));
E->m = (float**) malloc(n*sizeof(float*));
tmp->m = (float**) malloc(n*sizeof(float*));
tmp2->m = (float**) malloc(n*sizeof(float*));
tmp3->m = (float**) malloc(n*sizeof(float*));
 
 
for(i=0;i<n;i++)
{
A->m[i] = (float*) malloc(n*sizeof(float));
B->m[i] = (float*) malloc(n*sizeof(float));
C->m[i] = (float*) malloc(n*sizeof(float));
E->m[i] = (float*) malloc(n*sizeof(float));
tmp->m[i] = (float*) malloc(n*sizeof(float));
tmp2->m[i] = (float*) malloc(n*sizeof(float));
tmp3->m[i] = (float*) malloc(n*sizeof(float));
}
 
//
 
A->sz = n;
B->sz = n;
C->sz = n;
E->sz = n;
tmp->sz = n;
tmp2->sz = n;
tmp3->sz = n;
 
for(i=0;i<n;i++)
{
 for(j=0;j<n;j++)
 {
  if (i==j)
   E->m[i][j] = 1.0;
  else
   E->m[i][j] = 0.0;
 }
}
 
for(i=0;i<n;i++)
 for(j=0;j<n;j++)
   C->m[i][j] = 1.0/((float)(i+1)+(float)(j+1) ) ;
 
for(i=0;i<n;i++)
 for(j=0;j<n;j++)
   A->m[i][j] = 1.0/(float)(rand()%9+1) ;
 
 
for(i=0;i<n;i++)
 for(j=0;j<n;j++)
   B->m[i][j] = 1.0/(float)(rand()%9+1) ;
 
 
print_matrix(A);
print_matrix(B);
print_matrix(C);
print_matrix(E);
 
add_matrix(A, B, tmp);
print_matrix(tmp);
mul_matrix(tmp, A, tmp2);
print_matrix(tmp2);
cmul_matrix(3, B, tmp3);
print_matrix(tmp3);
sub_matrix(tmp2,tmp3, tmp);
print_matrix(tmp);
 
 
for(i=0;i<n;i++)
{
free (A->m[i]);
free (B->m[i]);
free (C->m[i]);
free (E->m[i]);
free (tmp->m[i]);
free (tmp2->m[i]);
free (tmp3->m[i]);
}
 
 
free (A->m);
free (B->m);
free (C->m);
free (E->m);
free (tmp->m);
free (tmp2->m);
free (tmp3->m);
 
free (A);
free (B);
free (C);
free (E);
free (tmp);
free (tmp2);
free (tmp3);
 
return 0;
}
2
0 / 0 / 0
Регистрация: 10.01.2013
Сообщений: 28
10.01.2013, 13:09  [ТС]
И все же помогите немного с кодом...

Добавлено через 49 секунд
asidorchenko, Спасибо тебе, добрый человек....Сейчас буду разбираться)
0
15 / 15 / 11
Регистрация: 06.12.2012
Сообщений: 131
10.01.2013, 13:21
Цитата Сообщение от Vlad Pisatel Посмотреть сообщение
И все же помогите немного с кодом...

Добавлено через 49 секунд
asidorchenko, Спасибо тебе, добрый человек....Сейчас буду разбираться)
С кодом нужно делать как говорил ntrx. Наверное самый простой способ.
1
0 / 0 / 0
Регистрация: 10.01.2013
Сообщений: 28
10.01.2013, 14:32  [ТС]
Все равно что-то не получается(
А вернее ничего не получается

Добрые люди, помогите!
0
123 / 123 / 82
Регистрация: 03.01.2013
Сообщений: 242
10.01.2013, 16:49
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
#include <iostream>
 
using namespace std;
int mAddition(int n,int m, float a[100][100], float b[100][100], float c[100][100]);
int mAddition(int n,int m, float a[100][100], float b[100][100], float c[100][100]) {
    for (int i=1; i<=n; i++) {
        for (int j=1; j<=m; j++) {
            c[i][j] = a[i][j] + b[i][j];
        }
    }
    return 0;
}
 
int mSubtraction(int n,int m, float a[100][100], float b[100][100], float c[100][100]);
int mSubtraction(int n,int m, float a[100][100], float b[100][100], float c[100][100]) {
    for (int i=1; i<=n; i++) {
        for (int j=1; j<=m; j++) {
            c[i][j] = a[i][j] - b[i][j];
        }
    }
    return 0;
}
 
int mMultiplication(int n,int m, float a[100][100], float b[100][100], float c[100][100]);
int mMultiplication(int n,int m, float a[100][100], float b[100][100], float c[100][100]) {
                for (int i=1; i<=m; i++) {
                        for (int j=1; j<=m; j++) {
                            c[i][j]=0;
                            for (int v=1; v<=n; v++) {
                                c[i][j] += a[i][v]*b[v][j];
                            }
                        }
                }
 
 
    return 0;
}
int mnMultiplication(int n,int m, float a[100][100], int k);
int mnMultiplication(int n,int m, float a[100][100], int k) {
    for (int i=1; i<=n; i++) {
        for (int j=1; j<=m; j++) {
            a[i][j] = k*a[i][j];
        }
    }
    return 0;
}
 
int main() {
    int n,m;
    float a[100][100],
          b[100][100],
          c[100][100],
          d[100][100];
          
    cout << "input array dimension (n m): ";
    cin >> n >> m;
    cout << endl;
    
    for (int i=1; i<=n; i++) {
        for (int j=1; j<=m; j++) {
            cout << "input a[" << i << "," << j << "]: ";
            cin >> a[i][j];
        }
    }
    cout << endl;
    for (int i=1; i<=n; i++) {
        for (int j=1; j<=m; j++) {
            cout << "input b[" << i << "," << j << "]: ";
            cin >> b[i][j];
        }
    }
    cout << endl;
    
    mAddition(n,m,a,b,c); // (a+b) = c
    mMultiplication(n,m,c,a,d); // c*a = d
    
    mnMultiplication(n,m,b,3); // 3*b = 3b 
    mSubtraction(n,m,d,b,c); // d-3b=c
    for (int i=1; i<=n; i++) {
        for (int j=1; j<=m; j++) {
            cout << c[i][j] << " ";
        }
        cout << endl;
    }
    return 0;
}
Условие на то, что максимальный размер 8х8, добавьте уже сами, забыл
1
0 / 0 / 0
Регистрация: 04.05.2020
Сообщений: 1
04.05.2020, 16:32
кто может помочь с составлением алгоритмов с помощью блок схем,используя конструкцию вычисления переменных и написать выражение на языке С++BORLAND 6??
0
04.05.2020, 17:44

Не по теме:

Кому нада С++BORLAND 6 в 2020??

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.05.2020, 17:44
Помогаю со студенческими работами здесь

Составить блок-схему алгоритма и программу вычисления выражения
Составить блок-схему алгоритма и программу вычисления выражения для заданных натурального числа n и действительного числа х

Составить блок-схему алгоритма и программу вычисления выражения
&lt;cut&gt; Рубят буду очень признателен,если кто-нибудь смоет помочь с заданиями 2.5.6.8. и 9 Хотя бы какое-нибудь. Я в этой теме полный...

Составить блок-схему алгоритма и программу вычисления выражения
функция Y Расчетные выражения = Ax2 + Bx = 5Ax + Sin Bx Условие Выбора выражения x &gt; 0 x &lt;= 0 Интервал изменения...

Составить блок-схему алгоритма и программу вычисления выражения согласно условию (условие прилагается)
Помогите составить блок-схему алгоритма и программку на с++ Формулы переписывайте в сообщение с помощью редактора внизу страницы

Написать программу вычисления выражения и составить блок-схему


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru